翻转句子中单词的顺序。
2015-05-31 16:59
232 查看
#include<iostream>
#include<string.h>
using namespace std;
/*
翻转句子中单词的顺序。
题目:输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变。
句子中单词以空格符隔开。为简单起见,标点符号和普通字母一样处理。
例如输入“I am a student.”,则输出“student. a am I”。
此题难度不大,主要是如何把句子中的字符串给分开存储
我用了一个二维数组存储,碰见空格则存储下一个字符串
存储完成后,再对二维数组的给每个子数组进行前后交换
*/
int main(void)
{
char s[20][20];
char s1[100],t[20];
cout << "请输入句子:";
gets(s1);
int flag = 1, n = 0, j = 0,len;
len = strlen(s1);
for (int i = 0; i<len; i++){
if (s1[i] == ' ') {
s
[j++] = 0;
n++;
j = 0;
continue;
}
s
[j++] = s1[i];
}
s
[j++] = 0;
for (int i = 0; i <= n / 2; i++)
{
strcpy(t, s[i]);
strcpy(s[i], s[n - i]);
strcpy(s[n - i], t);
}
cout << "翻转后的句子:";
for (int i = 0; i <= n; i++)
cout << s[i] <<" ";
return 0;
}
#include<string.h>
using namespace std;
/*
翻转句子中单词的顺序。
题目:输入一个英文句子,翻转句子中单词的顺序,但单词内字符的顺序不变。
句子中单词以空格符隔开。为简单起见,标点符号和普通字母一样处理。
例如输入“I am a student.”,则输出“student. a am I”。
此题难度不大,主要是如何把句子中的字符串给分开存储
我用了一个二维数组存储,碰见空格则存储下一个字符串
存储完成后,再对二维数组的给每个子数组进行前后交换
*/
int main(void)
{
char s[20][20];
char s1[100],t[20];
cout << "请输入句子:";
gets(s1);
int flag = 1, n = 0, j = 0,len;
len = strlen(s1);
for (int i = 0; i<len; i++){
if (s1[i] == ' ') {
s
[j++] = 0;
n++;
j = 0;
continue;
}
s
[j++] = s1[i];
}
s
[j++] = 0;
for (int i = 0; i <= n / 2; i++)
{
strcpy(t, s[i]);
strcpy(s[i], s[n - i]);
strcpy(s[n - i], t);
}
cout << "翻转后的句子:";
for (int i = 0; i <= n; i++)
cout << s[i] <<" ";
return 0;
}
相关文章推荐
- 动易2006序列号破解算法公布
- Ruby实现的矩阵连乘算法
- C#插入法排序算法实例分析
- C#数据结构与算法揭秘二
- 算法练习之从String.indexOf的模拟实现开始
- C#算法之关于大牛生小牛的问题
- C#实现的算24点游戏算法实例分析
- c语言实现的带通配符匹配算法
- 浅析STL中的常用算法
- 算法之排列算法与组合算法详解
- C++实现一维向量旋转算法
- Ruby实现的合并排序算法
- C#折半插入排序算法实现方法
- 基于C++实现的各种内部排序算法汇总
- C++线性时间的排序算法分析
- C++实现汉诺塔算法经典实例
- PHP实现克鲁斯卡尔算法实例解析
- C#常见算法面试题小结
- JavaScript 组件之旅(二)编码实现和算法
- JavaScript数据结构和算法之图和图算法