Lesson17.18语句作业
假设所有的变量都为int型,请写出下列各项变量的值:
y = x = (2+3)/4
答:5/4得到的是float,赋值给int ,没有强制转换,x = 0 y = 0
y = 4*8/(x=2*8)
答:x=16 y=2
x = (int)3.3+3.111
答:x = 0
y = 30.0/4.0*5.0
答:y = 0
x = 30/4.0*5
答:x = 0
请写出程序打印出来的值
int num = 10;
printf(“%d”,++num);
//答:num现在的值是:11,先自增
printf(“%d”,num++);
//答:现在num还是11,先赋值后自增
printf(“%d”,++num);
//答:现在num经过上条语句自增后为12,再先自增变为13
printf(“%d”,num--);
//答:现在num的值还是13,先赋值再自减,所以还是上条语句的值13
printf(“%d”,num);
//答:经过上条语句的后减减,变成12
请写出下面的程序打印出来的结果:
#include <stdio.h>
#define LENTH 10
int main()
{
int num = 0;
while(num++ < LENTH)
{
printf(“%5d”,num);
}
return 0;
}
答:打印出 1 2 3 4 5 6 7 8 9 10 , 5个宽度不足加空格
编程题
让用户不停输入分钟,程序自动换算为小时分钟的表示形式(不能出现魔数)。当用户输入0或小于0时程序结束
答:代码如下
#include <stdio.h> int main() { int minutes=1; while (minutes>0) { printf("\n请输入你要转换的分钟数:"); scanf_s("%d", &minutes); printf("\n成功转换成%d小时%d分钟!\n", (int)(minutes / 60), minutes % 60); } getchar(); return 0; }
让用户不停输入天数,程序自动换算为周数加天数的表示形式(不能出现魔数)。当用户输入0或小于0时程序结束
答:代码如下
#include <stdio.h> int main() { int datas = 1; while (datas > 0) { printf("\n请输入你要转换的天数:"); scanf_s("%d", &datas); printf("\n成功转换成%d周%d天!\n", (int)(datas / 7), datas % 7); } getchar(); return 0; }
请写出一个程序,要求用户输入:
总里程(公里)
跑过的距离(公里)
跑步用时(分钟)
请计算并显示出跑完全程还需要的时间(小时:分钟:秒)
答:代码如下
#include <stdio.h> int main() { int distance = 50; int runOver = 0; int times = 0; int speed = 0; while (distance>runOver) { printf("请输入3个数:1总里程数(公里)确定,2跑过的里程数(公里),3跑了多长时间(分钟):\n1,总里程(公里)数:"); scanf_s("%d", &distance); printf("\n请输入2跑过的里程数(公里):"); scanf_s("%d", &runOver); printf("请输入3跑了多长时间(分钟):"); scanf_s("%d", ×); if (distance>= runOver>0 && times >0) { speed = (int)runOver * 1000 / (int)times / 60; //每秒多少米 times = (int)((distance - runOver) * 1000 / speed); printf("\n你还需要%d小时%d分钟%d秒跑完!\n", times / 3600, (times % 3600) / 60, (times % 3600) % 60); } else { printf("输入不合理,程序即将退出!\n"); getchar(); return 1; } } getchar(); return 0; }
传说西塔发明了国际象棋而使国王十分高兴,他决定要重赏西塔,西塔说:“我不要你的重赏,陛下,只要你在我的棋盘上赏一些麦子就行了。在棋盘的第1个格子里放1粒,在第2个格子里放2粒,在第3个格子里放4粒,在第4个格子里放8粒,依此类推,以后每一个格子里放的麦粒数都是前一个格子里放的麦粒数的2倍,直到放满第64个格子就行了”。区区小数,几粒麦子,这有何难,“来人”,国王令人如数付给西塔。
请计算最后国王需要给西塔多少粒小麦,有多少吨(1粒/1克)
答:代码如下
#include<stdio.h> int main() { unsigned long long wheats = 1u, tmp = 1u; //超过了long long的范围, unsigned long long能表示。 for (int i = 1; i <= 63; i++) { tmp = tmp * 2; wheats += tmp; } printf("%I64u粒麦子\n", wheats); printf("如果1粒小麦算作1克,换算成吨,则是:%llu 吨!",wheats/1000/1000); getchar(); return 0; }