练习

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

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

输入格式:

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

输出格式:

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

输入样例:
  3 2

代码:

#include <stdio.h>

int main()
{ int A = ;
int B = ;
printf("请输入正整数 ");
scanf("%d %d",&A,&B);
printf("%d + %d = %d\n",A,B,A+B);
printf("%d - %d = %d\n",A,B,A-B);
printf("%d * %d = %d\n",A,B,A*B);
printf("%d / %d = %d\n",A,B,A/B);
return ;
}

02-0.c

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

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

输入格式:

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

输出格式:

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

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

#include <stdio.h>

int main()
{ int centimeter,intinch,foot;
float meter,inch;
scanf("%d",&centimeter); meter = centimeter / 100.0;
intinch = meter / 0.3048;
inch = meter / 0.3048; foot = (inch - intinch) * ;
printf("%d %d",intinch,foot);
return ; }

02-1.c

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

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

输入格式:

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

输出格式:

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

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

#include <stdio.h>

int main()
{
int start,lost_minute,end,hour,minute,lost_hour; scanf("%d %d",&start,&lost_minute); hour = start / ; minute = start - hour * ; lost_hour = (lost_minute + minute) / ; hour += lost_hour; minute = (lost_minute + minute) - lost_hour * ; if (minute < ){
hour --;
minute += ;
} printf("%d",hour*+minute); }

02-2.c

#include <stdio.h>

int main()
{
int start,lost_minute,hour,minute,all_minute; scanf("%d %d",&start,&lost_minute); hour = start / ; all_minute = start % + hour * + lost_minute ; hour = all_minute / ; minute = all_minute % ; printf("%d",hour*+minute); return ;
}

02-2.c

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

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

输入格式:

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

输出格式:

  输出按位逆序的数。

输入样例:

  123

输出样例:

  321

代码:

#include <stdio.h>

int main()
{
int num,a,b,c;
scanf("%d",&num); a = num / ;
b = (num - a*) / ;
c = num % ; printf("%d",c*+b*+a);
return ; }

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
代码:

#include <stdio.h>

int main()
{
int num, hex, a, b, c;
scanf("%d", &num); if (num >= && num <=){
hex = num;
}
else{
a = hex / ;
b = hex % ;
hex = a * +b;
} printf("%d",hex);
return ;
}

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

代码:

#include <stdio.h>

int main()
{
int speed;
scanf("%d",&speed); if (speed < ){
printf("Speed: %d - OK",speed);
}
else{
printf("Speed: %d - Speeding",speed);
}
}

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
代码:

#include <stdio.h>

int main(){
int day,n; scanf("%d",&day); n = day % ;
if (n <= && n >){
printf("Fishing in day %d",day);
}
else {
printf("Drying in day %d",day);
}
}

03-1.c

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

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

输入格式:

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

输出格式:

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

输入样例:

  1 1 2
输出样例:
  C
#include <stdio.h>

int main()
{
int a,b,c;
scanf("%d %d %d",&a,&b,&c);
if (a = b){
printf("C");
}
if (b = c){
printf("A");
}
if (a = c){
printf("B");
}
}

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
代码:

#include <stdio.h>

int main()
{
int hour,minute;
scanf("%d:%d",&hour,&minute); hour = hour % ;
if (hour == ){
hour = ;
}
if (hour < ){
printf("%d:%d AM",hour,minute);
}
else {
printf("%d:%d PM",hour,minute);
} }

03-3.c

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

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

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

输出格式:

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

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

#include <stdio.h>

int main(){

    int score;
scanf("%d",&score); if (score >= ){
printf("A");
}
else if (score >= ){
printf("B");
}
else if (score >= ){
printf("C");
}
else if (score >= ){
printf("D");
}
else {
printf("F");
}
}

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. Log4net 控制台打印日志(二)

    1.创建控制台程序 2.用NuGet添加log4net引用 3.添加应用程序配置文件:App.config 4.添加配置信息: <?xml version="1.0" enc ...

  2. If...else 条件判断和If else嵌套

    If(条件表达式){ 如果条件表达式结果为true,执行该处代码. 如果条件表达式结果为false,执行下边代码. }else{ 如果条件表达式结果为false,执行该处代码. } If(条件表达式) ...

  3. 洛谷P1043数字游戏

    题目 区间DP,将\(maxn[i][j][k]\)表示为i到j区间内分为k个区间所得到的最大值,\(minn\)表示最小值. 然后可以得到状态转移方程: \[maxn[i][j][k]= max(m ...

  4. Docker快速部署gitlab应用实战

    Gitlab是一个用于仓库管理系统开源项目,使用Git作为代码管理工具,并在此基础上搭建的web服务,可通过web界面进行访问公开或者私人项目,拥有类似于GIthub类似的功能,能够浏览源代码,可管理 ...

  5. Nginx简单配置几个基于端口的虚拟主机

    nginx.conf中,一个server段对应一个虚拟主机,如果要增加多个虚拟主机,增加多个server段即可. server { listen ; access_log logs/.log; loc ...

  6. ERROR: relation "pg_buffercache" does not exist

    创建pg_buffercache后,查询时报错: postgres=# create extension pg_buffercache; postgres=# select * from pg_buf ...

  7. idea搭建简单ssm框架的最详细教程(新)

    为开发一个测试程序,特搭建一个简单的ssm框架,因为网上看到很多都是比较老旧的教程,很多包都不能用了,eclipes搭建并且其中还附带了很多的其他东西,所以特此记录一下mac中idea搭建过程. 另: ...

  8. Spring cloud微服务安全实战-7-11PinPoint+SpringBoot环境搭建

    微服务的最后一个组件, 调用链监控,一个请求进来以后,经过N多个微服务,例如a调用了b.b又调用了c,那么在这个过程中看到,整个的调用的链路,然后每一段调用所耗费的时间,帮你去分析你的系统如果出现瓶颈 ...

  9. [LeetCode] 82. Remove Duplicates from Sorted List II 移除有序链表中的重复项 II

    Given a sorted linked list, delete all nodes that have duplicate numbers, leaving only distinct numb ...

  10. Kubernetes 基于 RBAC 的授权(十六)

    目录 一.RBAC介绍 1.1.角色和集群角色 1.2.RoleBinding 和 ClusterRoleBinding 1.3.资源 1.4.主体 二.命令行工具 2.1.kubectl creat ...