练习

02-0. 整数四则运算(10)

本题要求编写程序,计算2个正整数的和、差、积、商并输出。题目保证输入和输出全部在整型范围内。

输入格式:

  输入在一行中给出2个正整数A和B。

输出格式:

  在4行中按照格式“A 运算符 B = 结果”顺序输出和、差、积、商。

输入样例:
  3 2

代码:

  1. #include <stdio.h>
  2.  
  3. int main()
  4. {
  5.  
  6. int A = ;
  7. int B = ;
  8. printf("请输入正整数 ");
  9. scanf("%d %d",&A,&B);
  10. printf("%d + %d = %d\n",A,B,A+B);
  11. printf("%d - %d = %d\n",A,B,A-B);
  12. printf("%d * %d = %d\n",A,B,A*B);
  13. printf("%d / %d = %d\n",A,B,A/B);
  14. return ;
  15. }

02-0.c

02-1. 厘米换算英尺英寸(15)

如果已知英制长度的英尺foot和英寸inch的值,那么对应的米是(foot+inch/12)*0.3048。现在,如果用户输入的是厘米数,那么对应英制长度的英尺和英寸是多少呢?别忘了1英尺等于12英寸。

输入格式:

  输入在一行中给出1个正整数,单位是厘米。

输出格式:

  在一行中输出这个厘米数对应英制长度的英尺和英寸的整数值,中间用空格分开。

输入样例:
  170
输出样例:
  5 6
代码:

  1. #include <stdio.h>
  2.  
  3. int main()
  4. {
  5.  
  6. int centimeter,intinch,foot;
  7. float meter,inch;
  8. scanf("%d",&centimeter);
  9.  
  10. meter = centimeter / 100.0;
  11. intinch = meter / 0.3048;
  12. inch = meter / 0.3048;
  13.  
  14. foot = (inch - intinch) * ;
  15. printf("%d %d",intinch,foot);
  16. return ;
  17.  
  18. }

02-1.c

02-2. 然后是几点(15)

有时候人们用四位数字表示一个时间,比如1106表示11点零6分。现在,你的程序要根据起始时间和流逝的时间计算出终止时间。 读入两个数字,第一个数字以这样的四位数字表示当前时间,第二个数字表示分钟数,计算当前时间经过那么多分钟后是几点,结果也表示为四位数字。当小时为个位数时,没有前导的零,即5点30分表示为530。注意,第二个数字表示的分钟数可能超过60,也可能是负数。

输入格式:

  输入在一行中给出2个整数,分别是四位数字表示的起始时间、以及流逝的分钟数,其间以空格分隔。注意:在起始时间中,当小时为个位数时,没有前导的零,即5点30分表示为530;流逝的分钟数可能超过60,也可能是负数。

输出格式:

  输出四位数字表示的终止时间。题目保证起始时间和终止时间在同一天内。

输入样例:
  1120 110
输出样例:
  1310
代码:

  1. #include <stdio.h>
  2.  
  3. int main()
  4. {
  5. int start,lost_minute,end,hour,minute,lost_hour;
  6.  
  7. scanf("%d %d",&start,&lost_minute);
  8.  
  9. hour = start / ;
  10.  
  11. minute = start - hour * ;
  12.  
  13. lost_hour = (lost_minute + minute) / ;
  14.  
  15. hour += lost_hour;
  16.  
  17. minute = (lost_minute + minute) - lost_hour * ;
  18.  
  19. if (minute < ){
  20. hour --;
  21. minute += ;
  22. }
  23.  
  24. printf("%d",hour*+minute);
  25.  
  26. }

02-2.c

  1. #include <stdio.h>
  2.  
  3. int main()
  4. {
  5. int start,lost_minute,hour,minute,all_minute;
  6.  
  7. scanf("%d %d",&start,&lost_minute);
  8.  
  9. hour = start / ;
  10.  
  11. all_minute = start % + hour * + lost_minute ;
  12.  
  13. hour = all_minute / ;
  14.  
  15. minute = all_minute % ;
  16.  
  17. printf("%d",hour*+minute);
  18.  
  19. return ;
  20. }

02-2.c

02-3. 逆序的三位数(10)

程序每次读入一个正3位数,然后输出按位逆序的数字。注意:当输入的数字含有结尾的0时,输出不应带有前导的0。比如输入700,输出应该是7。

输入格式:

  每个测试是一个3位的正整数。

输出格式:

  输出按位逆序的数。

输入样例:

  123

输出样例:

  321

代码:

  1. #include <stdio.h>
  2.  
  3. int main()
  4. {
  5. int num,a,b,c;
  6. scanf("%d",&num);
  7.  
  8. a = num / ;
  9. b = (num - a*) / ;
  10. c = num % ;
  11.  
  12. printf("%d",c*+b*+a);
  13. return ;
  14.  
  15. }

02-3.c

02-4. BCD解密(10)
BCD数是用一个字节来表达两位十进制的数,每四个比特表示一位。所以如果一个BCD数的十六进制是0x12,它表达的就是十进制的12。但是小明没学过BCD,把所有的BCD数都当作二进制数转换成十进制输出了。于是BCD的0x12被输出成了十进制的18了!

现在,你的程序要读入这个错误的十进制数,然后输出正确的十进制数。提示:你可以把18转换回0x12,然后再转换回12。

输入格式:

  输入在一行中给出一个[0, 153]范围内的正整数,保证能转换回有效的BCD数,也就是说这个整数转换成十六进制时不会出现A-F的数字。

输出格式:

  输出对应的十进制数。

输入样例:
  18
输出样例:
  12
代码:

  1. #include <stdio.h>
  2.  
  3. int main()
  4. {
  5. int num, hex, a, b, c;
  6. scanf("%d", &num);
  7.  
  8. if (num >= && num <=){
  9. hex = num;
  10. }
  11. else{
  12. a = hex / ;
  13. b = hex % ;
  14. hex = a * +b;
  15. }
  16.  
  17. printf("%d",hex);
  18. return ;
  19. }

02-4.c

03-0. 超速判断(10)
模拟交通警察的雷达测速仪。输入汽车速度,如果速度超出60 mph,则显示“Speeding”,否则显示“OK”。

输入格式:

  输入在一行中给出1个不超过500的非负整数,即雷达测到的车速。

输出格式:

  在一行中输出测速仪显示结果,格式为:“Speed: V - S”,其中V是车速,S或者是Speeding、或者是OK。

输入样例1:
  40
输出样例1:
  Speed: 40 - OK
输入样例2:
  75
输出样例2:
  Speed: 75 - Speeding

代码:

  1. #include <stdio.h>
  2.  
  3. int main()
  4. {
  5. int speed;
  6. scanf("%d",&speed);
  7.  
  8. if (speed < ){
  9. printf("Speed: %d - OK",speed);
  10. }
  11. else{
  12. printf("Speed: %d - Speeding",speed);
  13. }
  14. }

03-0.c

03-1. 三天打鱼两天晒网(15)

中国有句俗语叫“三天打鱼两天晒网”。假设某人从某天起,开始“三天打鱼两天晒网”,问这个人在以后的第N天中是“打鱼”还是“晒网”?

输入格式:

  输入在一行中给出1个不超过1000的正整数N。

输出格式:

  在一行中输出此人在第N天中是“Fishing”(即“打鱼”)还是“Drying”(即“晒网”),并且输出“in day N”。

输入样例1:
  103
输出样例1:
  Fishing in day 103
输入样例2:
  34
输出样例2:
  Drying in day 34
代码:

  1. #include <stdio.h>
  2.  
  3. int main(){
  4. int day,n;
  5.  
  6. scanf("%d",&day);
  7.  
  8. n = day % ;
  9. if (n <= && n >){
  10. printf("Fishing in day %d",day);
  11. }
  12. else {
  13. printf("Drying in day %d",day);
  14. }
  15. }

03-1.c

03-2. 用天平找小球(10)

三个球A、B、C,大小形状相同且其中有一个球与其他球重量不同。要求找出这个不一样的球。

输入格式:

  输入在一行中给出3个正整数,顺序对应球A、B、C的重量。

输出格式:

  在一行中输出唯一的那个不一样的球。

输入样例:

  1 1 2
输出样例:
  C
  1. #include <stdio.h>
  2.  
  3. int main()
  4. {
  5. int a,b,c;
  6. scanf("%d %d %d",&a,&b,&c);
  7. if (a = b){
  8. printf("C");
  9. }
  10. if (b = c){
  11. printf("A");
  12. }
  13. if (a = c){
  14. printf("B");
  15. }
  16. }

03-2.c

03-3. 12-24小时制(15)
编写一个程序,要求用户输入24小时制的时间,然后显示12小时制的时间。

输入格式:

  输入在一行中给出带有中间的“:”符号(半角的冒号)的24小时制的时间,如12:34表示12点34分。当小时或分钟数小于10时,均没有前导的零,如5:6表示5点零6分。

  提示:在scanf的格式字符串中加入“:”,让scanf来处理这个冒号。

输出格式:

  在一行中输出这个时间对应的12小时制的时间,数字部分格式与输入的相同,然后跟上空格,再跟上表示上午的字符串“AM”或表示下午的字符串“PM”。如“5:6 PM”表示下午5点零6分。注意,在英文的习惯中,中午12点被认为是下午,所以24小时制的12:00就是12小时制的12:0 PM;而0点被认为是第二天的时间,所以是0:0 AM。

输入样例:
  21:11
输出样例:
  9:11 PM
代码:

  1. #include <stdio.h>
  2.  
  3. int main()
  4. {
  5. int hour,minute;
  6. scanf("%d:%d",&hour,&minute);
  7.  
  8. hour = hour % ;
  9. if (hour == ){
  10. hour = ;
  11. }
  12. if (hour < ){
  13. printf("%d:%d AM",hour,minute);
  14. }
  15. else {
  16. printf("%d:%d PM",hour,minute);
  17. }
  18.  
  19. }

03-3.c

03-4. 成绩转换(15)
本题要求编写程序将一个百分制成绩转换为五分制成绩。转换规则:

  大于等于90分为A;小于90且大于等于80为B;小于80且大于等于70为C;小于70且大于等于60为D;小于60为E。
输入格式:

  输入在一行中给出1个整数的百分制成绩。

输出格式:

  在一行中输出对应的五分制成绩。

输入样例:
  90
输出样例:
  A
代码:

  1. #include <stdio.h>
  2.  
  3. int main(){
  4.  
  5. int score;
  6. scanf("%d",&score);
  7.  
  8. if (score >= ){
  9. printf("A");
  10. }
  11. else if (score >= ){
  12. printf("B");
  13. }
  14. else if (score >= ){
  15. printf("C");
  16. }
  17. else if (score >= ){
  18. printf("D");
  19. }
  20. else {
  21. printf("F");
  22. }
  23. }

03-4.c

中国大学MOOC-翁恺-C语言程序设计习题集(一)的更多相关文章

  1. 中国大学MOOC-翁恺-C语言程序设计习题集-解答汇总

    中国大学MOOC-翁恺-C语言程序设计习题集 PAT 习题集 02-0. 整数四则运算(10) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standar ...

  2. 中国大学MOOC-翁恺-C语言程序设计习题集

    今年网易出了“中国大学MOOC”,于是选了浙大翁恺老师的“C语言程序设计”学习,近期打算把自己在该课程中的PAT习题解答做一个记录,等自己编程能力提高后再来看现在写的代码哪里还有写的不好,可以改进的地 ...

  3. 中国大学MOOC-翁恺-C语言程序设计习题集(二)

    04-0. 求符合给定条件的整数集(15)给定不超过6的正整数A,考虑从A开始的连续4个数字.请输出所有由它们组成的无重复数字的3位数. 输入格式: 输入在一行中给出A. 输出格式: 输出满足条件的的 ...

  4. 中国大学MOOC中的后台文件传输

    早期版本的中国大学MOOC一旦被挂起后,应用在完成当前下载任务后无法继续添加新任务,当然也无法将缓存状态写入数据库.这个问题能否顺利解决直接关系到用户体验. 顺便吐槽下,凡是使用了后台文件传输还提示你 ...

  5. 中国大学mooc直播回放看这里哦http://www.icourse163.org/forum/1001974001/topic-1003372881.htm?sortType=1&pageIndex=1

    中国大学mooc直播回放看这里哦http://www.icourse163.org/forum/1001974001/topic-1003372881.htm?sortType=1&pageI ...

  6. 中国大学MOOC课程信息之数据分析可视化二

    版权声明:本文为博主原创文章,转载 请注明出处:https://blog.csdn.net/sc2079/article/details/82318571 - 写在前面 本篇博客继续对中国大学MOOC ...

  7. 中国大学MOOC课程信息之数据分析可视化一

    版权声明:本文为博主原创文章,转载 请注明出处:https://blog.csdn.net/sc2079/article/details/82263391 9月2日更:中国大学MOOC课程信息之数据分 ...

  8. 中国大学MOOC课程信息爬取与数据存储

    版权声明:本文为博主原创文章,转载 请注明出处: https://blog.csdn.net/sc2079/article/details/82016583 10月18日更:MOOC课程信息D3.js ...

  9. 中国大学MOOC 邮箱验证的问题

    在使用 中国大学 MOOC 过程中,在PC端修改个人资料时,其中有项“常用邮箱”,于是写了QQ邮箱,结果发现一直无法验证,连邮件都无法收到. 经过多番尝试,重新使用邮箱注册的方式注册账号,然后注册成功 ...

随机推荐

  1. 干货 | 列生成VRPTW子问题ESPPRC( Elementary shortest path problem with resource constraints)介绍附C++代码

    00 前言 各位小伙伴大家好,相信大家已经看过前面column generation求解vehicle routing problems的过程详解.该问题中,子问题主要是找到一条reduced cos ...

  2. SP19997 MOON2 - Moon Safari (Hard) 【数论,多项式】

    题目描述:求 \[ \sum_{i=1}^ni^kr^i \] 对某个质数取模.\(T\)组数据. 数据范围:\(n,r\le 10^{18},\sum k\le 2.56\times 10^6\) ...

  3. Java中定义不了可变长数组怎么办---集合 泛型

    一.集合(Collections) Java使用集合来组织和管理对象. 1.Java的集合类 集合类主要负责保存.盛装和管理对象,因此集合类也被称为容器类. 集合类分为Set.List.Map和Que ...

  4. 测试linux下磁盘的读写速率

    1) 通过df -h命令查看磁盘情况 Filesystem            Size  Used Avail Use% Mounted on/dev/sda4             289G  ...

  5. Monkey框架(测试方法篇) - monkey测试实例

    一.常规的稳定性测试 测试背景: 这是一个海外的合作项目,被测程序是Android应用(App).测试希望通过Monkey来模拟用户长时间的随机操作,检查被测应用是否会出现异常(应用崩溃或者无响应). ...

  6. python在windows上创建虚拟环境

    cmd进入 安装virtualenvwrapper-win pip install virtualenvwrapper-win 创建名为pyve的虚拟环境 mkvirtualenv pyve 退出虚拟 ...

  7. QString 中文编码转换

      版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明. 本文链接:https://blog.csdn.net/xxm524/article/det ...

  8. vue+websocket demo 实例

    vue+websocket demo: <!-- vue + websocket连接demo --> <template> <div class="" ...

  9. Nginx系列 | [转]Nginx 上传文件:client_max_body_size 、client_body_buffer_size

    原文:http://php-note.com/article/detail/488 client_max_body_size client_max_body_size 默认 1M,表示 客户端请求服务 ...

  10. # advanced packaging

    目录 advanced packaging ASM NEXX ASMPT完成收購NEXX 準備就緒迎接先進半導體封裝之高速增長 Intro Bumping 产品供应 晶圆溅镀– Apollo 300 ...