#include<stdio.h>
int main()
{
float m;
int grade;
printf("请输入成绩:");
scanf("%f",&m);
if(m>=0&&m<=100)
{
grade=(int)m/10;
}
else
{
printf("您输入的成绩无效");
}
switch(grade)
{case 0:
case 1:
case 2:
case 3:
case 4:
case 5:("不及格");break;
case 6:printf("及格");break;
case 7:printf("一般");break;
case 8:printf("良好");break;
case 9:
case 10:printf("优秀");break;
}
return 0;
}
请问我这串代码应该怎么修改会更简洁呢?
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
关注 改成if/elseif语句会好一点,因为你这里的case0-6都没东西,看上去就很空
我帮你改了一下#include<stdio.h> int main() { float m; int grade=0; printf("请输入成绩:"); scanf("%f", &m); if (m >= 0 && m <= 100) grade = (int)m / 10; else { printf("您输入的成绩无效\n"); exit(-1);//成绩无效,退出程序 } if (grade < 6) printf("不及格\n"); else if (grade >= 6 && grade < 7) printf("及格\n"); else if (grade >= 7 && grade < 8) printf("一般\n"); else if (grade >= 8 && grade < 9) printf("良好\n"); else if (grade >= 9 && grade < 10) printf("优秀\n"); else printf("完美\n"); return 0; }
还有几个小问题
- grade应该初始化为0,不然你输入的数据不在0-100范围内,grade就是随机值,到下面的switch语句会出错
- 为了避免上面说的这个情况,输入错误的时候,应该直接停止程序
- if后面如果只有单个语句,可以不用加
{ }
,这样可以节省一点代码行数,哈哈
如果对你有帮助,还请点个采纳,万分感谢!
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 1无用
悬赏问题
- ¥60 pb数据库修改或者求完整pb库存系统,需为pb自带数据库
- ¥15 spss统计中二分类变量和有序变量的相关性分析可以用kendall相关分析吗?
- ¥15 拟通过pc下指令到安卓系统,如果追求响应速度,尽可能无延迟,是不是用安卓模拟器会优于实体的安卓手机?如果是,可以快多少毫秒?
- ¥20 神经网络Sequential name=sequential, built=False
- ¥16 Qphython 用xlrd读取excel报错
- ¥15 单片机学习顺序问题!!
- ¥15 ikuai客户端多拨vpn,重启总是有个别重拨不上
- ¥20 关于#anlogic#sdram#的问题,如何解决?(关键词-performance)
- ¥15 相敏解调 matlab
- ¥15 求lingo代码和思路