单词反转
题目遇到几次,来个总结
由简到难吧~
走起~~~
一
输入一个单词,将单词反转。
输入:hello
输出:olleh
解法一:(就很简单的方法)
#include <cstdio>
#include <cstring>
int main(){
char s[100];int l;
gets(s);
l=strlen(s);
for(int i=l-1;i>=0;--i)
printf("%c",s[i]);
return 0;
}
解法二:递归来解决
#include <cstdio>
#include <cstring>
void inv(char *a)
{
if(*a=='\0')return ;
inv(a+1);
printf("%c",*a);
return ;
}
int main(){
char s[10];
gets(s);
inv(s);
}
二
输入一个句子(英文的)整体反转输出
输入:my name is wyf
输出:fyw si eman ym
第一题解法一 一样的程序
#include <cstdio>
#include <cstring>
int main(){
char s[100];int l;
gets(s);
l=strlen(s);
for(int i=l-1;i>=0;--i)
printf("%c",s[i]);
return 0;
}
三
输入一个句子,将句子中的每一个单词反转后输出
输入:hello world
输出:olleh dlrow
#include <cstdio>
#include <cstring>
int main(){
char a[1000];int x=0,y;
gets(a);//gets输入字符串
int l,j;
l=strlen(a);//计算长度
a[l]=' ' ;//末尾增加一个空格方便计算
for(int i=0;i<=l;++i)
{
if(a[i]!=' ')x=x+1;//计算单词长度
else
{
y=i;//单词末尾的位置
for(int j=1;j<=x;++j)
printf("%c",a[--y]);//从后往前输出
x=0;
if(i!=l)//如果不是自己增加 的空格就输出
printf(" ");
}
}
return 0;
}