//以下将单词逆序输出,如:good morning 输出为 morning good
//先来最笨的方法:把单词一个个放人新的二维数组中,然后把二维数组按照行的逆序输出
int fun(char *p,int len)
{
int i=0,flag=0,j=0;
int word=0;
char tem[100][100]={0};//存放单词
while(p[i])
{
while(((p[i]==' ')||(p[i]=='\t'))&&p[i])//一直移动到空格结束,不能用if语句,因为那只判断一次
{flag=0;i++;}
while((p[i]!=' ')&&p[i]&&(p[i]!='\t'))//一直移动到单词结束,也不能用if语句
{
tem[word][j]=p[i];j++;
flag=1;i++;
}
tem[word][j]='\0';//结束该单词输入
j=0; //用来开始下一个单词
if(flag==1) word++;
}
printf("word=%d\n",word);
for(i=0;i<word;i++)
printf("%s\n",tem[i]);
for(j=word-1;j>=0;j--) //逆序输出单词
printf("%s\t",tem[j]);
return word;
}
int main()
{
char str[100];
int len=0;
puts("Input the array:");
gets(str);
len=strlen(str);
fun(str,len);
return 0;
}
逆序输出单词
最新推荐文章于 2022-04-08 22:01:59 发布