题目链接
A - C语言实验——求绝对值(选择结构)使用if选择语句, 大于等于 0 直接输出, 小于 0 输出 -x 即可
拓展: 求绝对值的函数code A
头文件下有abs() 和 fabs() 两个函数, 分别可以返回整数和浮点型的原数的绝对值
//if分支语句 #includeint main() { int x; scanf("%d", &x); if(x >= 0) printf("%d", x); else printf("%d", -x); return 0; }
//使用abs()函数 #includeB - C语言实验——时间间隔#include int main() { int x; scanf("%d", &x); printf("%d", abs(x)); return 0; }
- 我们可以使用统一单位的方法, 把两个时间段统一化成秒为单位
- 根据两个时间化成秒后的大小, 可以通过交换, 让较小的时间在前面
- 将两个时间作差得到两个时间的差值, 再将其还原成小时和分钟
- 时间是60进制, 可以类比10进制的方式思考
- 一个三位的十进制数, % 10 得到的是个位, / 10 得到的是个位之前的数, / 100得到的是百位, % 100 得到的是去掉最高位后剩下的数, 如123, 百位为123 / 100 = 1, 个位为123 % 10 = 3, 可以理解成, /10就是从十位切一刀, 然后取前半部分; 而 %10 相当于从10位切一刀, 然后取后半部分, 这样想得到中间的数字, 可以从后往前取, 也就是123 / 10 = 12, 12 % 10 = 2; 也可以从前往后取, 也就是123 % 100 = 23, 23 / 10 = 2;
- 按照同样的方式, 从我们已经得到的10进制的时间差, 转换为3位(时、分、秒) 的60进制 时间, 记时间差为t, 时 = t / 3600, 秒 = t % 60, 分 = t / 60 % 60 (从后往前) 或 分 = t % 3600 / 60(从前往后)
#includeC - C语言实验——求两个整数之中较大者int main() { int h1, m1, s1; //第一个时间的时分秒 int h2, m2, s2; //第二个时间的时分秒 scanf("%d:%d:%d", &h1, &m1, &s1); scanf("%d:%d:%d", &h2, &m2, &s2); int t1 = h1 * 3600 + m1 * 60 + s1; int t2 = h2 * 3600 + m2 * 60 + s2; //将两个时间转换成以秒为单位 if(t1 > t2) //如果t1大,交换t1和t2,目的是让t2 >= t1, 直接用t2 - t1求时间差 (当然也可以用abs(t1 - t2)求时间差) { int t = t1; t1 = t2; t2 = t; } int t = t2 - t1; //t为时间差, 交换后t2一定比t1大 printf("%02d:%02d:%02d", t / 3600, t / 60 % 60, t % 60); return 0; }
用if来判断较大值即可
code C#includeD - 小鑫吃苹果int main() { int a, b, max; scanf("%d %d", &a, &b); if(a > b) max = a; else max = b; printf("max=%d", max); return 0; }
跟上题相同, 都是找两个数的最大值, 直接if比较即可
code D#includeE - 小鑫の日常系列故事(一)——判断对错int main() { int a, b, max; scanf("%d %d", &a, &b); if(a > b) max = a; else max = b; printf("%d", max); return 0; }
仍然是直接用if判断c是否等于a + b之和
code E#includeF - 小鑫追女神int main() { int a, b, c; scanf("%d %d %d", &a, &b, &c); if(c == a + b) printf("YESn"); else printf("NOn"); return 0; }
判断输入是0是1即可, 可以直接用简写, if(n) 表示n != 0, if(!n) 表示n == 0
code F#includeG - C语言实验——求三个整数的最大值int main() { int n; scanf("%d", &n); if(n) printf("I like you"); else printf("He he"); return 0; }
可以对三个数排序, 排序完之后最大值最小值中间值就都可以求了;
也可以用打擂法来求max,min, 也就是初始化一个非常小的max(非常大的min), 遇到更大的(更小的)更新这个值, 最后留下的即为这些值全部的最大值or最小值, 在循环和数组章节中会经常见到打擂法
code G对三个数排序, 最多需要3个if即可, 首先比较ab, 然后比较bc, 最后再比较一次ab
如要让a b c从小到大排序 (a < b < c)
首先比较是否a > b, 如果是则交换a b, 交换后b的值为a和b中的较大值
然后比较是否b > c, 如果是则交换b c, 交换后c的值为b和c中的较大值, 此时的c一定为a b c中的最大值
最后比较是否a > b, 如果是则交换a b, 交换后满足a <= b, 而c已经确保为三个数中的最大值了, 排序完成
//排序 #includeint main() { int a, b, c; scanf("%d,%d,%d", &a, &b, &c); if(a > b) { int t = a; a = b; b = t; } if(b > c) { int t = b; b = c; c = t; } if(a > b) { int t = a; a = b; b = t; } printf("max=%d", c); //交换完之后c为max return 0; }
//打擂法可以求max或者min #includeH - 相加和最大值int main() { int a, b, c; scanf("%d,%d,%d", &a, &b, &c); int max = -2e9; // 表示2 * 10的9次方, 为max初始化一个极小的数 if(a > max) max = a; if(b > max) max = b; if(c > max) max = c; printf("max=%d", max); //交换完之后c为max return 0; }
可以对三个数排序, 最大的两个数相加的和一定是最大的;
也可以分别两两求和, 再求最大值
#includeint main() { int a, b, c; scanf("%d %d %d", &a, &b, &c); if(a > b) { int t = a; a = b; b = t; } if(b > c) { int t = b; b = c; c = t; } if(a > b) { int t = a; a = b; b = t; } printf("%d", b + c); //最大俩数加起来一定是最大的和 return 0; }
//俩俩求和, 这里还是用的与上题相同的打擂法的思想 #includeI - 时间格式转换int main() { int a, b, c; scanf("%d %d %d", &a, &b, &c); int max = -2e9; // 表示2 * 10的9次方, 为max初始化一个极小的数 if(a + b > max) max = a + b; if(b + c > max) max = b + c; if(c + a > max) max = c + a; printf("%d", max); return 0; }
只需要分类表示每一种情况即可, 注意用%02d控制输出的格式, 这个题时不能用%02d,分需要用%02d
code I//简化版, 需要处理好边界 #includeint main() { int h, m; scanf("%d:%d", &h, &m); int hh, mm = m;//转换后的时和分, 分和原来的分相同 //按照h来分类 if(h == 0 || h == 12) hh = 12; //h = 0和h = 12两个条件可以合并 else if(h <= 11) hh = h; //h >= 1这个条件可以省略不写 else hh = h - 12; //除此之外的时间即为h >= 13 到 h <= 23之内的 if(h < 12) printf("%d:%02d AM", hh, mm); //注意后面的AM和PM else printf("%d:%02d PM", hh, mm); return 0; }
//详细版, 如果不好考虑边界条件可以完完全全按照题目说的来写 #includeJ - C语言实验——从大到小输出a、b、c(选择结构)int main() { int h, m; scanf("%d:%d", &h, &m); int hh, mm; if(h == 0) hh = 12; else if(h >= 1 && h <= 11) hh = h; else if(h == 12) hh = 12; else if(h >= 13 && h <= 24) hh = h - 12; mm = m; if((h == 0) || (h >= 1 && h <= 11)) printf("%d:%02d AM", hh, mm); if((h == 12) || (h >= 13 && h <= 23)) printf("%d:%02d PM", hh, mm); return 0; }
按照G思路对三个数排序即可
code J#includeK - C语言实验——三个数排序int main() { int a, b, c; scanf("%d%d%d", &a, &b, &c); if(a > b) { int t = a; a = b; b = t; } if(b > c) { int t = b; b = c; c = t; } if(a > b) { int t = a; a = b; b = t; } printf("%d %d %d", c, b, a); return 0; }
与上一个题完全相同, 输入中间是逗号
code K#includeL - C语言实验——找中间数int main() { int a, b, c; scanf("%d,%d,%d", &a, &b, &c); if(a > b) { int t = a; a = b; b = t; } if(b > c) { int t = b; b = c; c = t; } if(a > b) { int t = a; a = b; b = t; } printf("%d %d %d", a, b, c); return 0; }
仍像G或前两个题一样, 对三个数进行排序, 输出中间值即可
code L#includeM - C语言实验——整除int main() { int a, b, c; scanf("%d%d%d", &a, &b, &c); if(a > b) { int t = a; a = b; b = t; } if(b > c) { int t = b; b = c; c = t; } if(a > b) { int t = a; a = b; b = t; } printf("%d", b); return 0; }
用&&(与)把两个条件连起来即可
ps: 当你找不到wa哪里的时候不妨看看是不是输出大小写的问题
code M#includeN - 闰年int main() { int n; scanf("%d", &n); if(n % 5 == 0 && n % 3 == 0) printf("Yes"); else printf("No"); return 0; }
判断闰年的条件: 能被400整除 或者 能被4整除但不能被100整除
code N#includeO - C/C++经典程序训练3—模拟计算器 知识点: 吃掉行末空格int main() { int n; scanf("%d", &n); if(n % 400 == 0 || n % 4 == 0 && n % 100) printf("Yes"); else printf("No"); return 0; }
code Oscanf %c 不会跳过空白符(如空格’ ‘或换行符’n’), 因此当数字后面有换行符(或空格)而后需要读入字母的时候需要吃掉行末换行符(空格符)
- 可以用getchar()直接吃掉行末的换行或者空格
- 可以设一个无关char类型变量, 然后用scanf %c 吃掉换行或者空格
#includeP - C语言实验——某年某月的天数int main() { int a, b; char c; scanf("%d%d", &a, &b); getchar(); //吃掉行末换行 scanf("%c", &c); int ans; if(c == '+') ans = a + b; else if(c == '-') ans = a - b; else if(c == '*') ans = a * b; else ans = a / b; printf("%d", ans); return 0; }
注意判断闰年即可
可以用switch case语句来写, 注意在除最后一个分支下添加break即可
#includeint main() { int y, m; scanf("%d\%d", &y, &m); if(m == 1 || m == 3 || m == 5 || m == 7 || m == 8 || m == 10 || m == 12) printf("31"); else if(m == 4 || m == 6 || m == 9 || m == 11) printf("30"); else //二月需要特别处理 { if(y % 400 == 0 || y % 4 == 0 && y % 100 != 0) printf("29"); else printf("28"); } return 0; }
//switch case写 #includeQ - C语言实验——输入数字星期,输出英文(switch语句)int main() { int y, m; scanf("%d\%d", &y, &m); switch(m) { case 1: case 3: case 5: case 7: case 8: case 10: case 12: printf("31"); break; case 4: case 6: case 9: case 11: printf("30"); break; default: if(y % 400 == 0 || y % 4 == 0 && y % 100 != 0) printf("29"); else printf("28"); } return 0; }
- switch-case 语句记得在除了最后一条分支以外的所有分支加上break, break相当于switch的开关,不加的话switch会一直往下滑, 并输出滑过的所有结果
#include题解仅供参考, 一定要多敲多思考!!! 有问题欢迎在评论区指出或单独联系我!int main() { int d; scanf("%d", &d); switch(d) { case 1: printf("Monday"); break; case 2: printf("Tuesday"); break; case 3: printf("Wednesday"); break; case 4: printf("Thursday"); break; case 5: printf("Friday"); break; case 6: printf("Saturday"); break; case 7: //可以写default printf("Sunday"); //最后一个可以不加break } return 0; }



