#include
#include
int main()
{
int ch,i=0,k=-1;
char *p,a[81];
p=a; //定义一个指针指向a,a是数组a的首地址
while((ch=getchar())!='\n') //该循环通过输入为数组赋值
{
if(i<80)
a[i++]=ch;
}
a[i]='\0';//数组在字符最后添加空,形成字符串
k=strcspn(a,"");//在查找a中查找后一个字符串第一次出现的位置
if(k {
p=strrchr(a,' ');//倒序查找' ‘所在的地址
while(p!=(a+k)) //若p=a+k,则表示两次查找到的位置相同,
//p为' '的地址,a+k也是地址(a_k的地址)
{
p=strrchr(a,' ');
printf("%s ",p+1); //输出后数第一个' '后的字符串
*(p)='\0';//将' '改为'\0',实际上把字符串在这里截短,
//例如a原本输入的是b c d(中间有空格),第一次输出d之后,字符串变成b c,
//第二次就会输出c
}
}
printf("%s\n",a);//输出最后个字符串上例的话是b,如果输入的字符串a没空格就这全输出了
return0;
}
这个函数的功能就是将输入的字符串中的每个以空格分割的序列倒序输出。
财富值太少了!再加一点我就给你注释