您的位置:首页 > 运维架构 > Linux

linux 中 句子的逆序“you are from yangzhou”

2017-07-18 00:50 411 查看
关于句子的逆序,我们首先想到的是把它们先逆序过来,然后找到空格,定义3个指针p1,p2,p3,先用俩个指针来完成句子的逆序,在用p2跑完整个句子,遇到空格就”报告“一次,再将p2空格前的值 赋给指针,再来完成单个句子的逆序。

#include <stdio.h>
#include <string.h>

int main()
{
// char *p = "i am are from yangzhou";
// char str[] = "i am from yangzhou";
char str[] = "you are from yangzhou";

// 将整个字符串逆序
char *p1 = str;
char *p2 = str + strlen(str) - 1;
char *p3 = NULL;  // 用于将单词逆序
char tmp;
while (p1 < p2)
{
tmp = *p1;
*(p1++) = *p2;
*(p2--) = tmp;
}
puts(str);

// 再将每一个单词进行逆序,单词通过空格去找
p1 = str;
p2 = str;

while(*p2) // p2找到字符串结束为止
{
if (*p2 == ' ') // 找到一个单词,要将前面的单词进行逆序
{
p3 = p2 - 1;
while (p1 < p3)
{
tmp = *p1;
*(p1++) = *p3;
*(p3--) = tmp;
}
p1 = p2 + 1;
}
p2++;
}

p3 = p2 - 1;
while (p1 < p3)
{
tmp = *p1;
*(p1++) = *p3;
*(p3--) = tmp;
}

puts(str);

return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: 
相关文章推荐