-
读代码

cnt值是fib运行了几次: -
main()函数的位置:

main()函数可以在任意位置 -

我不知道的:一个C源程序必须包含一个main()函数
找最小公倍数(快速)
- 确定m、n中较小值 min
- min * 1, *2,*3。。。
- min1, min2, min*3,去试%另外一个数是否为0,就是最小公倍数
逆序单词,但所有单词有序,且标点符号不变
思路:标点符合也算入到单词中即可
- 全体逆序
- 单个单词再逆序
- 注意点:
end后挪时,判断条件同时考虑不是空格和\0
且end++要判断排除\0以外情况,\0就到末尾了
然后start = end后,下次循环也不会走了。

void swap(char* left, char* right)
{
while (left < right)
{
char t = *left;
*left = *right;
*right = t;
left++;
right--;
}
}
// 逆序整个字符串,逆序每个单词
int main()
{
char s[15] = { 0 };
gets(s);
int sz = strlen(s);
// 整体逆序
swap(s, s + sz - 1);
printf("全体逆转完之后是:%s\n", s);
// 每个逆序
char* start = s;
char* end = start;
// \0为假,不需要判断
while (*start)
{
// 如果是刚刚开始,end应该和start一起走
// 如果是换完一个单词,end应该=start,因为start为下个单词首字母,且如果我接着上次,end在end++
printf("现在的start字符是%c\n", *start);
printf("现在的end字符是%c\n", *end);
while (*end != ' ' && *end != '\0')
{
end++;
}
swap(start, end - 1);
// 现在end指着空格 让它往后用++
// start接收end,start现在在空格后 第一个字母
if (*end != '\0')
{
end++;
}
start = end;
}
printf("%s", s);
return 0;
}
C语言字符串逆序及单词排序
本文介绍了一个使用C语言实现的字符串逆序及单词排序的程序。该程序首先将整个字符串逆序,然后单独逆序每个单词,并保持标点符号的位置不变。通过具体示例代码展示了如何实现这一功能。
+字符串中单词逆转&spm=1001.2101.3001.5002&articleId=124962227&d=1&t=3&u=fe7b3838bfa441f899346b16535d0fd4)

被折叠的 条评论
为什么被折叠?



