-
读代码
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;
}