将一句话的单词进行倒置

比如说一句话,“I love you!”变成“you! love I”,

char *Reverse(char *s)
{
 int n=strlen(s);
 char temp[1000];//定义缓冲区的的大小
 int q=n-1;
 temp[n]='\0';  //最后一个为‘\0’
 char *p;
 p=s;
 int i=0,t=0;
 bool flag=true;
 while(flag)
 {
  if (*p==' ')
  {
   p--;
   while(t!=0)
   {
    temp[q]=*p;
    p--;
    q--;
    t--;
   }
   temp[q]=' ';
   q--;
   i+=2;
   p+=i;
   i=0;
   t=0;
  }else if (*p=='\0') //如果运行到字符串的末尾
  {
   p--;
   while(t!=0)
   {
    temp[q]=*p;
    p--;
    q--;
    t--;
   }
   //break;
   flag=false;
  }
  p++;
  i++;
  t++;
 }
 for(i=0;i<n;i++)
 {
  printf("%c",temp[i]);//重新赋给字符串
 }
 return s;
}

相关文章

什么是设计模式一套被反复使用、多数人知晓的、经过分类编目...
单一职责原则定义(Single Responsibility Principle,SRP)...
动态代理和CGLib代理分不清吗,看看这篇文章,写的非常好,强...
适配器模式将一个类的接口转换成客户期望的另一个接口,使得...
策略模式定义了一系列算法族,并封装在类中,它们之间可以互...
设计模式讲的是如何编写可扩展、可维护、可读的高质量代码,...