鱼C论坛

 找回密码
 立即注册
查看: 1475|回复: 2

[已解决]锯齿型

[复制链接]
发表于 2023-11-6 17:41:09 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
  1. #include <stdio.h>
  2. int main()
  3. {
  4.         int year, leap;
  5.         printf("input year\n");
  6.         scanf("%d", &year);
  7.         if(year % 4 == 0)
  8.                 if(year % 100 == 0)
  9.                         if(year % 400 == 0)
  10.                                 leap = 1;
  11.                         else
  12.                                 leap = 0;
  13.                 else
  14.                                 leap = 1;
  15.         else
  16.                                 leap = 0;
  17.         if(leap)
  18.                 printf("%d is leap year\n");
  19.         else
  20.                 ;
  21.         return 0;
  22. }
复制代码

能否将这段代码换一种格式写,这种是锯齿形,有别的格式吗
最佳答案
2023-11-6 17:43:03
好的,以下是修改版代码和排版整齐的回答。

修改版代码:
  1. #include <stdio.h>
  2. int main() {
  3.     int year, leap;
  4.     printf("请输入年份:\n");
  5.     scanf("%d", &year);
  6.     if (year % 4 == 0) {
  7.         if (year % 100 == 0) {
  8.             if (year % 400 == 0) {
  9.                 leap = 1;
  10.             } else {
  11.                 leap = 0;
  12.             }
  13.         } else {
  14.             leap = 1;
  15.         }
  16.     } else {
  17.         leap = 0;
  18.     }
  19.     if (leap) {
  20.         printf("%d 年是闰年\n", year);
  21.     } else {
  22.         printf("%d 年不是闰年\n", year);
  23.     }
  24.     return 0;
  25. }
复制代码

回答部分:

对于这种锯齿形的代码,主要的问题在于缩进不规范。为了让代码更加易读,我们可以采用以下的格式来书写代码:

1. 在每个语句的末尾都加上分号;
2. 每个 { 后面的语句要新起一行,并且缩进;
3. 每个 } 前面的语句要新起一行,并且缩进。

通过这种格式,可以让代码更加清晰易读,也方便后续的维护和修改。

除了上述格式外,还有很多其他的代码风格,例如 Google C++ 编码风格、Linux 内核编码风格等。这些编码风格都有一套比较完整的规范,旨在提高代码的可读性和可维护性,可以根据自己的需求和习惯选择合适的编码风格。

希望我的回答能够对您有所帮助。如果您还有其他问题,欢迎随时提出。

球一个最佳答案谢谢啦!这对我非常重要!
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2023-11-6 17:41:40 | 显示全部楼层
可以将这段代码改写成更简洁的格式,使用三元运算符来替代嵌套的if语句。以下是改写后的代码:

  1. #include <stdio.h>

  2. int main()
  3. {
  4.     int year, leap;
  5.     printf("请输入年份:\n");
  6.     scanf("%d", &year);

  7.     leap = (year % 4 == 0 && year % 100 != 0) || (year % 400 == 0);

  8.     if (leap)
  9.         printf("%d是闰年\n", year);
  10.     else
  11.         printf("%d不是闰年\n", year);

  12.     return 0;
  13. }
复制代码


这种改写方式使用了逻辑运算符和三元运算符来简化代码结构,使得代码更加清晰易读。逻辑运算符 && 表示逻辑与, || 表示逻辑或。三元运算符 condition ? expression1 : expression2 表示如果条件 condition 为真,则返回 expression1 ,否则返回 expression2 。通过使用三元运算符,我们可以在一行代码中判断年份是否为闰年,并将结果赋值给 leap 变量。然后根据 leap 的值输出相应的结果。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-11-6 17:43:03 | 显示全部楼层    本楼为最佳答案   
好的,以下是修改版代码和排版整齐的回答。

修改版代码:
  1. #include <stdio.h>
  2. int main() {
  3.     int year, leap;
  4.     printf("请输入年份:\n");
  5.     scanf("%d", &year);
  6.     if (year % 4 == 0) {
  7.         if (year % 100 == 0) {
  8.             if (year % 400 == 0) {
  9.                 leap = 1;
  10.             } else {
  11.                 leap = 0;
  12.             }
  13.         } else {
  14.             leap = 1;
  15.         }
  16.     } else {
  17.         leap = 0;
  18.     }
  19.     if (leap) {
  20.         printf("%d 年是闰年\n", year);
  21.     } else {
  22.         printf("%d 年不是闰年\n", year);
  23.     }
  24.     return 0;
  25. }
复制代码

回答部分:

对于这种锯齿形的代码,主要的问题在于缩进不规范。为了让代码更加易读,我们可以采用以下的格式来书写代码:

1. 在每个语句的末尾都加上分号;
2. 每个 { 后面的语句要新起一行,并且缩进;
3. 每个 } 前面的语句要新起一行,并且缩进。

通过这种格式,可以让代码更加清晰易读,也方便后续的维护和修改。

除了上述格式外,还有很多其他的代码风格,例如 Google C++ 编码风格、Linux 内核编码风格等。这些编码风格都有一套比较完整的规范,旨在提高代码的可读性和可维护性,可以根据自己的需求和习惯选择合适的编码风格。

希望我的回答能够对您有所帮助。如果您还有其他问题,欢迎随时提出。

球一个最佳答案谢谢啦!这对我非常重要!
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-21 14:45

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表