飞道的博客

C语言刷题(3)——“C”

672人阅读  评论(0)

各位CSDN的uu们你们好呀,今天小雅兰的内容还是做几道题噢,好好复习一下之前的知识点,现在,就让我们开始复习吧

牛客网在线编程_编程学习|练习题_数据结构|系统设计题库

倒置字符串_牛客题霸_牛客网


BC40 竞选社长

BC41 你是天才吗?

BC42 完美成绩

BC43 及格分数

BC44 判断整数奇偶性

BC45 最高分数

BC46 判断是元音还是辅音

BC47 判断是不是字母

BC48 字母大小写转换

BC49 判断两个数的大小关系

BC50 计算单位阶跃函数

BC51 三角形判断

BC52 衡量人体胖瘦程度

BC53 计算一元二次方程

BC54 获得月份天数

OR62 倒置字符串


 

 

此代码用到了gets这个库函数 


  
  1. #include<stdio.h>
  2. int main()
  3. {
  4. char buf[ 100] = { 0 };
  5. //输入
  6. gets(buf);
  7. int count_a = 0;
  8. int count_b = 0;
  9. int i = 0;
  10. while (buf[i] != '0')
  11. {
  12. if (buf[i] == 'A')
  13. {
  14. count_a++;
  15. }
  16. else if (buf[i] = 'B')
  17. {
  18. count_b++;
  19. }
  20. i++;
  21. }
  22. if (count_a > count_b)
  23. {
  24. printf( "A\n");
  25. }
  26. else if (count_a < count_b)
  27. {
  28. printf( "B\n");
  29. }
  30. else if(count_a==count_b)
  31. {
  32. printf( "E\n");
  33. }
  34. return 0;
  35. }

这段代码还可以再改进一下,可不可以不定义两个变量呢?这当然也是可以的。


  
  1. #include<stdio.h>
  2. int main()
  3. {
  4. char arr[ 100]= { 0 };
  5. gets(arr);
  6. int i = 0 ;
  7. int flag = 0 ;
  8. while( arr[i] != '0')
  9. {
  10. if(arr[i] == 'A')
  11. {
  12. flag++;
  13. }
  14. else if(arr[i] == 'B')
  15. {
  16. flag--;
  17. }
  18. i++;
  19. }
  20. if (flag > 0)
  21. {
  22. printf( "A");
  23. }
  24. else if (flag < 0)
  25. {
  26. printf( "B");
  27. }
  28. else
  29. {
  30. printf( "E");
  31. }
  32. return 0;
  33. }

那么只定义一个变量的方法我们也掌握了,那么,还有没有其他的写法呢?比如不用gets,这当然也是可以的。

下面这段代码使用了getchar

 

getchar拓展_认真学习的小雅兰.的博客-CSDN博客


  
  1. #include <stdio.h>
  2. int main()
  3. {
  4. char arr[ 100] = { 0 };
  5. int ch = 0 ;
  6. int flag = 0 ;
  7. //如果getchar获取了
  8. while (((ch= getchar()) != '0') && ch!= EOF)
  9. {
  10. if(ch== 'A')
  11. {
  12. flag++;
  13. }
  14. else if(ch== 'B')
  15. {
  16. flag--;
  17. }
  18. }
  19. if (flag > 0)
  20. {
  21. printf( "A");
  22. }
  23. else if (flag < 0)
  24. {
  25. printf( "B");
  26. }
  27. else
  28. {
  29. printf( "E");
  30. }
  31. return 0;
  32. }

1. 本题有很多解法。

2. 主要就是读取输入数据的问题要解决好,输入有2个结束条件(遇到读取结束EOF,或者'0')。

3. 剩余的工作就是统计个数后,然后根据情况按照格式输出。

 


  
  1. #include <stdio.h>
  2. int main()
  3. {
  4. int a= 0;
  5. while( scanf( "%d",&a)!=EOF)
  6. {
  7. if(a>= 140)
  8. {
  9. printf( "Genius\n");
  10. }
  11. else
  12. {
  13. printf( "不是天才\n");
  14. }
  15. }
  16. return 0;
  17. }

这个代码还有另外一种写法:


  
  1. #include<stdio.h>
  2. int main()
  3. {
  4. int n = 0;
  5. //这种写法是因为scanf读取失败返回EOF,EOF是-1,所以按位取反后的结果是0,0为假,可以让循环停止。
  6. while (~ scanf( "%d", &n))
  7. {
  8. if (n >= 140)
  9. {
  10. printf( "Genius");
  11. }
  12. else
  13. {
  14. printf( "不是天才\n");
  15. }
  16. }
  17. return 0;
  18. }

关于对组输入的题目,一定要处理好多组数据的输入问题,然后考虑循环如何结束。

这里写到了一个操作符—— ~ 

 操作符的详细知识可以看小雅兰的博客噢

操作符——“C”_认真学习的小雅兰.的博客-CSDN博客_十进制数10可以表示为

整型提升+算术转换——“C”_认真学习的小雅兰.的博客-CSDN博客


  
  1. #include <stdio.h>
  2. int main()
  3. {
  4. int score = 0;
  5. while ( scanf( "%d", &score) != EOF)
  6. {
  7. if (score >= 90 && score <= 100)
  8. printf( "Perfect");
  9. }
  10. return 0;
  11. }

1. 多组输入。

2. 数学中的 90的写法,在C语言中直接写是有bug的。

 


  
  1. #include <stdio.h>
  2. int main()
  3. {
  4. int score = 0;
  5. while ( scanf( "%d", &score) != EOF)
  6. {
  7. if (score >= 60)
  8. printf( "Pass\n");
  9. else
  10. printf( "Fail\n");
  11. }
  12. return 0;
  13. }


  
  1. #include <stdio.h>
  2. int main()
  3. {
  4. int i= 0;
  5. while( scanf( "%d",&i)!=EOF)
  6. {
  7. if(i% 2== 0)
  8. printf( "Even\n");
  9. else if(i% 2!= 0)
  10. printf( "Odd\n");
  11. }
  12. return 0;
  13. }

 这几道题目都是类似的。

 


  
  1. #include<stdio.h>
  2. int main()
  3. {
  4. int n1 = 0;
  5. int n2 = 0;
  6. int n3 = 0;
  7. while ( scanf( "%d %d %d", &n1, &n2, &n3) != EOF)
  8. {
  9. int max = n1 > n2 ? n1 : n2;
  10. max = max > n3 ? max : n3;
  11. printf( "%d\n", max);
  12. }
  13. return 0;
  14. }

另一种写法:


  
  1. #include <stdio.h>
  2. int main()
  3. {
  4. int i = 0;
  5. int score[ 3] = { 0 };
  6. while ( scanf( "%d %d %d", &score[ 0], &score[ 1], &score[ 2]) != EOF)
  7. {
  8. int max = 0; //每一组测试,max都恢复到0
  9. int i = 0;
  10. for (i = 0; i < 3; i++)
  11. {
  12. if (score[i] > max)
  13. max = score[i];
  14. }
  15. printf( "%d\n", max);
  16. }
  17. return 0;
  18. }

1. 多组输入

2. 每组输入接受3个数字,求出最大值,因为成绩不能是负数,所以假设max期初是0.

 


  
  1. #include <stdio.h>
  2. int main()
  3. {
  4. char ch = 0;
  5. //存放元音字母的数组
  6. char arr[] = "AEIOUaeiou";
  7. //输入
  8. while ((ch = getchar()) != EOF)
  9. {
  10. //判断
  11. int i = 0;
  12. for (i = 0; i < 10; i++)
  13. {
  14. if (ch == arr[i])
  15. {
  16. printf( "Vowel\n");
  17. break;
  18. }
  19. }
  20. if (i == 10)
  21. printf( "Consonant\n");
  22. getchar(); //去除每个字符后的\n
  23. }
  24. return 0;
  25. }

当然,这个代码还可以用库函数——strchr

 


  
  1. #include<stdio.h>
  2. #include<string.h>
  3. int main()
  4. {
  5. int ch = 0;
  6. //存放元音字母的数组
  7. char vowel[] = "AEIOUaeiou";
  8. //输入
  9. while (ch = getchar() != EOF)
  10. {
  11. //判断
  12. //strchr是用来判断ch是否在字符串vowel中出现
  13. //如果出现了,则返回在vowel字符串中的地址
  14. //如果没出现,则返回NULL
  15. if ( strchr(vowel, ch))
  16. {
  17. printf( "Vowel\n");
  18. }
  19. else
  20. {
  21. printf( "Constantly\n");
  22. }
  23. getchar(); //处理\n
  24. }
  25. return 0;
  26. }

另一种写法:


  
  1. #include <stdio.h>
  2. int main()
  3. {
  4. char ch = 0;
  5. char arr[] = "AEIOUaeiou";
  6. //在%c的前面写一个空格会消化掉前面所有的空白字符,然后读取一个字符
  7. while ( scanf( " %c", &ch) != EOF)
  8. {
  9. int i = 0;
  10. for (i = 0; i < 10; i++)
  11. {
  12. if (ch == arr[i])
  13. {
  14. printf( "Vowel\n");
  15. break;
  16. }
  17. }
  18. if (i == 10)
  19. printf( "Consonant\n");
  20. }
  21. return 0;
  22. }

另一种写法:


  
  1. #include<stdio.h>
  2. int main()
  3. {
  4. char ch = 0;
  5. char arr[] = "AEIOUaeiou";
  6. //在%c的后边发给一个'\n',其实在输入时候就会消化掉这个\n字符
  7. //不会为下次留下空白字符的隐患
  8. while ( scanf( "%c\n", &ch) != EOF)
  9. {
  10. int i = 0;
  11. for (i = 0; i < 10; i++)
  12. {
  13. if (ch == arr[i])
  14. {
  15. printf( "Vowel\n");
  16. break;
  17. }
  18. }
  19. if (i == 10)
  20. printf( "Consonant\n");
  21. }
  22. return 0;
  23. }


  
  1. #include <stdio.h>
  2. int main()
  3. {
  4. int ch = 0;
  5. while ((ch = getchar()) != EOF)
  6. {
  7. if ((ch >= 'A' && ch <= 'Z') || (ch >= 'a' && ch <= 'z'))
  8. {
  9. printf( "%c is an alphabet.\n", ch);
  10. }
  11. else
  12. {
  13. printf( "%c is not an alphabet.\n", ch);
  14. }
  15. //清理掉\n
  16. getchar();
  17. }
  18. return 0;
  19. }

当然,也可以用库函数,专门用来判断是不是字母——isalpha


  
  1. #include <stdio.h>
  2. int main()
  3. {
  4. int ch = 0;
  5. while ((ch = getchar()) != EOF)
  6. {
  7. if ( isalpha(ch))
  8. {
  9. printf( "%c is an alphabet.\n", ch);
  10. }
  11. else
  12. {
  13. printf( "%c is not an alphabet.\n", ch);
  14. }
  15. //清理掉\n
  16. getchar();
  17. }
  18. return 0;
  19. }

 


  
  1. #include <stdio.h>
  2. #include<ctype.h>
  3. int main()
  4. {
  5. int ch = 0;
  6. while ((ch = getchar()) != EOF)
  7. {
  8. if ( isalpha(ch))
  9. {
  10. printf( "%c is an alphabet.\n", ch);
  11. }
  12. else
  13. {
  14. printf( "%c is not an alphabet.\n", ch);
  15. }
  16. //清理掉\n
  17. getchar();
  18. }
  19. return 0;
  20. }

 

 

 


  
  1. #include<stdio.h>
  2. int main()
  3. {
  4. char ch = 0;
  5. while ( scanf( "%c", &ch) != EOF)
  6. {
  7. if (ch >= 'A' && ch <= 'Z')
  8. {
  9. printf( "%c\n", ch + 32);
  10. }
  11. else if (ch >= 'a' && ch <= 'z')
  12. {
  13. printf( "%c\n",ch - 32);
  14. }
  15. }
  16. return 0;
  17. }

当然,还有其他的写法,这里可以用到我们的库函数——islower,是专门用来判断小写字母的。

toupper——将小写字母转换为大写字母

tolower——将大写字母转换为小写字母

isupper——专门用来判断大写字母

 

 

 

 

 


  
  1. #include<stdio.h>
  2. #include<ctype.h>
  3. int main()
  4. {
  5. int ch = 0;
  6. //多组输入
  7. while ((ch = getchar()) != EOF)
  8. {
  9. if ( islower(ch))
  10. {
  11. printf( "%c\n", toupper(ch));
  12. }
  13. else
  14. {
  15. printf( "%c\n", tolower(ch));
  16. }
  17. //处理'\n'
  18. getchar();
  19. }
  20. return 0;
  21. }

 


  
  1. #include <stdio.h>
  2. int main()
  3. {
  4. int i= 0;
  5. int j= 0;
  6. while( scanf( "%d %d",&i,&j)!=EOF)
  7. {
  8. if(i>j)
  9. {
  10. printf( "%d>%d",i,j);
  11. }
  12. else if(i==j)
  13. {
  14. printf( "%d=%d",i,j);
  15. }
  16. else if(i<j)
  17. {
  18. printf( "%d<%d",i,j);
  19. }
  20. printf( "\n");
  21. }
  22. return 0;
  23. }

 


  
  1. #include<stdio.h>
  2. int main()
  3. {
  4. int t = 0;
  5. while ( scanf( "%d", &t) != EOF)
  6. {
  7. if (t > 0)
  8. {
  9. printf( "%d\n", 1);
  10. }
  11. else if (t == 0)
  12. {
  13. printf( "%.1f\n", 0.5f);
  14. }
  15. else
  16. {
  17. printf( "%d\n", 0);
  18. }
  19. }
  20. return 0;
  21. }


  
  1. #include <stdio.h>
  2. int main()
  3. {
  4. int a= 0;
  5. int b= 0;
  6. int c= 0;
  7. while( scanf( "%d %d %d",&a,&b,&c)!=EOF)
  8. {
  9. if(a+b>c&&a+c>b&&b+c>a&&a-b<c&&a-c<b&&b-c<a)
  10. {
  11. if(a==b&&b==c&&a==c)
  12. {
  13. printf( "Equilateral triangle!\n");
  14. }
  15. else if((a==b&&b!=c&&a!=c)||(a==c&&a!=b&&c!=b)||(b==c&&b!=a&&c!=a))
  16. {
  17. printf( "Isosceles triangle!\n");
  18. }
  19. else
  20. {
  21. printf( "Ordinary triangle!\n");
  22. }
  23. }
  24. else
  25. {
  26. printf( "Not a triangle!\n");
  27. }
  28. }
  29. return 0;
  30. }

 这里就是搞清楚三角形的判断规则,并去一一穷举就行了,因为只有三条边。


  
  1. #include<stdio.h>
  2. int main()
  3. {
  4. float weight = 0.0;
  5. float hight = 0.0;
  6. while ( scanf( "%f %f", &weight, &hight) != EOF)
  7. {
  8. float bmi = weight / (hight * hight / 100 / 100);
  9. if (bmi < 18.5)
  10. {
  11. printf( "Underweight\n");
  12. }
  13. else if (bmi >= 18.5 && bmi <= 23.9)
  14. {
  15. printf( "Normal\n");
  16. }
  17. else if (bmi > 23.9 && bmi <= 27.9)
  18. {
  19. printf( "Overweight\n");
  20. }
  21. else
  22. {
  23. printf( "Obese\n");
  24. }
  25. }
  26. return 0;
  27. }

1. 多组输入

2. 浮点数除法要保证除号的两端至少有一个浮点数

 

 


  
  1. #include <stdio.h>
  2. #include <math.h>
  3. int main()
  4. {
  5. float a = 0.0;
  6. float b = 0.0;
  7. float c = 0.0;
  8. while ( scanf( "%f %f %f", &a, &b, &c) != EOF)
  9. {
  10. if (a != 0)
  11. {
  12. float disc = b * b - 4 * a * c;
  13. if (disc > 0.0)
  14. {
  15. //有两个不相等的实根
  16. printf( "x1=%.2f;x2=%.2f\n",
  17. (-b - sqrt(disc)) / ( 2 * a),
  18. (-b + sqrt(disc)) / ( 2 * a)
  19. );
  20. }
  21. else if (disc < 0.0)
  22. {
  23. //有两个虚根
  24. printf( "x1=%.2f-%.2fi;x2=%.2f+%.2fi\n",
  25. (-b) / ( 2 * a), sqrt(-disc) / ( 2 * a),
  26. (-b) / ( 2 * a), sqrt(-disc) / ( 2 * a));
  27. }
  28. else
  29. {
  30. //有两个相等的实根
  31. printf( "x1=x2=%.2f\n", (-b) / ( 2 * a));
  32. }
  33. }
  34. else
  35. {
  36. printf( "Not quadratic equation\n");
  37. }
  38. }
  39. return 0;
  40. }

1. 多组输入

2. 根据不同的限制条件给出相应的计算结果

3. 小数点数后位数有限制

 


  
  1. #include <stdio.h>
  2. int main()
  3. {
  4. int y = 0;
  5. int m = 0;
  6. int days[ 12] = { 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 };
  7. while ( scanf( "%d%d", &y, &m) != EOF)
  8. {
  9. int day = days[m - 1];
  10. if ((y % 4 == 0 && y % 100 != 0) || (y % 400 == 0))
  11. {
  12. if (m == 2)
  13. day += 1;
  14. }
  15. printf( "%d\n", day);
  16. }
  17. return 0;
  18. }

1. 多组输入

2. 判断闰年,如果是闰年,2月多一天,其他都正常。

 


  
  1. #include<stdio.h>
  2. #include<string.h>
  3. #include<assert.h>
  4. void reverse(char* left, char* right)
  5. {
  6. assert(left != NULL);
  7. assert(right != NULL);
  8. while (left < right)
  9. {
  10. char* tmp = *left;
  11. *left = *right;
  12. *right = tmp;
  13. left++;
  14. right--;
  15. }
  16. }
  17. int main()
  18. {
  19. char arr[ 100] = { 0 };
  20. gets(arr); //输入
  21. int len = strlen(arr); //求字符串的长度
  22. //1.逆序整个字符串
  23. reverse(arr, arr + len - 1);
  24. //2.逆序每个单词
  25. char* cur = arr;
  26. while (*cur)
  27. {
  28. //找一个单词
  29. char* start = cur;
  30. while (*cur != ' ' && *cur != '\0')
  31. {
  32. cur++;
  33. //遇到空格,说明走到一个单词的最后面
  34. //遇到\0,说明已经走到字符串的最后面
  35. //这两种情况下都需要cur++
  36. }
  37. reverse(start, cur - 1);
  38. if (*cur == ' ')
  39. {
  40. cur++;
  41. //跳过空格
  42. }
  43. }
  44. printf( "%s\n", arr);
  45. return 0;
  46. }

好啦,小雅兰今天的复习内容就到这里啦,以后的内容必定更加精彩!!!

 


转载:https://blog.csdn.net/weixin_74957752/article/details/129226260
查看评论
* 以上用户言论只代表其个人观点,不代表本网站的观点或立场