ImageVerifierCode 换一换
格式:DOCX , 页数:17 ,大小:19.93KB ,
资源ID:6287558      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/6287558.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(经典练习c语言编程的题目及答案整理.docx)为本站会员(b****6)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

经典练习c语言编程的题目及答案整理.docx

1、经典练习c语言编程的题目及答案整理1.逆序输出正三位数#include int main()int input,output= 0; scanf(%d,&input);while(input != 0) output = output*10 + input%10; input /= 10; printf(%dn,output); return 0;2.百元找零函数#include int main() int amount=100; int price=0; printf(请输入金额(元)); scanf(%d,&price); printf(请输入票面); scanf(%d,&amount)

2、; int change=amount-price; printf(找您%d元。n,change); return 0;3.求平均数#include int main() int a,b; scanf(%d %d,&a,&b); double c=(a+b)/2.0;/* scanf(%d,&amount); 这是注释,我随便放的,没意义 int change=amount-price;*/ printf(%d和%d的平均值是%fn,a,b,c); return 0;4.写出程序的输出:inti=1; switch(i/3) case0:printf(zero); case1:printf(o

3、ne); case2:printf(two); 正确答案是:zeroonetwo。5.水仙花数是指一个N位正整数(N=3),它的每个位上的数字的N次幂之和等于它本身。例 如:153 = 13+ 53+33。 本题要求编写程序,计算所有N位水仙花数。输入格式:输入在一行中给出一个正整数N(3=N=7)。输出格式:按递增顺序输出所有N位水仙花数,每个数字占一行。输入样例:3输出样例:153370371407#include int main(void) int i, j, n, low = 1, high, temp, sum, item, remainder; scanf(%d, &n); fo

4、r(i = 1; i n; +i) low *= 10; /* 得到n位数的下限 */ high = low * 10; /* 得到n位数的上限 */ for(i = low; i 0) remainder = temp % 10; item = remainder; for(j = 1; j n; +j) item *= remainder; sum += item; temp /= 10; if(i = sum) printf(%dn, i); return 0;6.时间换算UTC是世界协调时,BJT是北京时间,UTC时间相当于BJT减去8。现在,你的程序要读入一个整数,表示BJT的时和分

5、。整数的个位和十位表示分,百位和千位表示小时。如果小时小于10,则没有千位部分;如果小时是0,则没有百位部分;如果分小于10分,需要保留十位上的0。如1124表示11点24分,而905表示9点5分,36表示0点36分,7表示0点7分。有效的输入范围是0到2359,即你的程序不可能从测试服务器读到0到2359以外的输入数据。你的程序要输出这个时间对应的UTC时间,输出的格式和输入的相同,即输出一个整数,表示UTC的时和分。整数的个位和十位表示分,百位和千位表示小时。如果小时小于10,则没有千位部分;如果小时是0,则没有百位部分;如果分小于10分,需要保留十位上的0。提醒:要小心跨日的换算。输入格

6、式:一个整数,表示BJT的时和分。整数的个位和十位表示分,百位和千位表示小时。如果小时小于10,则没有千位部分;如果小时是0,则没有百位部分;如果分小于10分,需要保留十位上的0。输出格式:一个整数,表示UTC的时和分。整数的个位和十位表示分,百位和千位表示小时。如果小时小于10,则没有千位部分;如果小时是0,则没有百位部分;如果分小于10分,需要保留十位上的0。输入样例:903输出样例:103时间限制:500ms内存限制:32000kb#include int main() int h,m,input,b; scanf(%d,&input); h = input/100; m = input

7、%100; if (h=8) printf(%d,b = (h-8)*100+m); else printf(%d,b = (h+24-8)*100+m); return 0; 7. 信号报告题目内容:无线电台的RS制信号报告是由三两个部分组成的:R(Readability) 信号可辨度即清晰度.S(Strength) 信号强度即大小.其中R位于报告第一位,共分5级,用15数字表示.1-Unreadable2-Barely readable, occasional words distinguishable3-Readable with considerable difficulty4-Rea

8、dable with practically no difficulty5-Perfectly readable报告第二位是S,共分九个级别,用19中的一位数字表示1-Faint signals, barely perceptible2-Very weak signals3-Weak signals4-Fair signals5-Fairly good signals6-Good signals7-Moderately strong signals8-Strong signals9-Extremely strong signals现在,你的程序要读入一个信号报告的数字,然后输出对应的含义。如读

9、到59,则输出:Extremelystrongsignals,perfectlyreadable.输入格式:一个整数,信号报告。整数的十位部分表示可辨度,个位部分表示强度。输入的整数范围是11,59,这个范围外的数字不可能出现在测试数据中。输出格式:一句话,表示这个信号报告的意义。按照题目中的文字,先输出表示强度的文字,跟上逗号和空格,然后是表示可辨度的文字,跟上句号。注意可辨度的句子的第一个字母是小写的。注意这里的标点符号都是英文的。输入样例:33输出样例:Weaksignals,readablewithconsiderabledifficulty.#include int main() i

10、nt rs; scanf(%d,&rs);if(rs % 10 != 0) int r = rs / 10; int s = rs % 10; switch(s) case 1: printf(Faint signals,barely perceptible,); break; case 2: printf(Very weaksignals,); break; case 3: printf(Weak signals,); break; case 4: printf(Fair signals,); break; case 5: printf(Fairly goodsignals,); break

11、; case 6: printf(Good signals,); break; case 7: printf(Moderately strongsignals,); break; case 8: printf(Strong signals,); break; case 9: printf(Extremely strongsignals,); break; switch(r) case 1: printf(unreadable.); break; case 2: printf(barely readable,occasional words distinguishable.); break; c

12、ase 3: printf(readable withconsiderable difficulty.); break; case 4: printf(readable withpractically no difficulty.); break; case 5: printf(perfectly readable.); break; return 0; 也可以写成下面这样:#include int main() int s; int r; int n; scanf(%d,&n); r=n/10; s=n%10; switch(s) case 0:printf(); case 1:printf

13、(Faint signals, barely perceptible, );break; case 2:printf(Very weak signals, );break; case 3:printf(Weak signals, );break; case 4:printf(Fair signals, );break; case 5:printf(Fairly good signals, );break; case 6:printf(Good signals, );break; case 7:printf(Moderately strong signals, );break; case 8:p

14、rintf(Strong signals, );break; case 9:printf(Extremely strong signals, );break; switch(r) case 0:printf(); case 1:printf(unreadable.);break; case 2:printf(barely readable, occasional words distinguishable.);break; case 3:printf(readable with considerable difficulty.);break; case 4:printf(readable wi

15、th practically no difficulty.);break; case 5:printf(perfectly readable.);break; return 0;8. 数字特征值题目内容:对数字求特征值是常用的编码算法,奇偶特征是一种简单的特征值。对于一个整数,从个位开始对每一位数字编号,个位是1号,十位是2号,以此类推。这个整数在第n位上的数字记作x,如果x和n的奇偶性相同,则记下一个1,否则记下一个0。按照整数的顺序把对应位的表示奇偶性的0和1都记录下来,就形成了一个二进制数字。比如,对于342315,这个二进制数字就是001101。这里的计算可以用下面的表格来表示:数字3

16、42315数位654321数字奇偶奇偶偶奇奇奇数位奇偶偶奇偶奇偶奇奇偶一致001101二进制位值32168421按照二进制位值将1的位的位值加起来就得到了结果13。你的程序要读入一个非负整数,整数的范围是0,100000,然后按照上述算法计算出表示奇偶性的那个二进制数字,输出它对应的十进制值。提示:将整数从右向左分解,数位每次加1,而二进制值每次乘2。输入格式:一个非负整数,整数的范围是0,100000。输出格式:一个整数,表示计算结果。输入样例:342315输出样例:13#include stdio.h#include math.h/使用pow函数需要引用int main() /number

17、:输入的正整数;ret:结果 int number=-1,ret=0; scanf(%d,&number); if(number0 & number0 ); printf(%d,ret); return 0; 9. 奇偶个数题目内容:你的程序要读入一系列正整数数据,输入-1表示输入结束,-1本身不是输入的数据。程序输出读到的数据中的奇数和偶数的个数。输入格式:一系列正整数,整数的范围是(0,100000)。如果输入-1则表示输入结束。输出格式:两个整数,第一个整数表示读入数据中的奇数的个数,第二个整数表示读入数据中的偶数的个数。两个整数之间以空格分隔。输入样例:9 3 4 2 5 7 -1输出

18、样例:4 2#include int main() int a,i=0,j=0; do scanf(%d,&a); if(a%2=1) i+; if(a%2=0) j+; while(a!=-1); printf(%d %d,i,j); return 0;10. 素数和题目内容:我们认为2是第一个素数,3是第二个素数,5是第三个素数,依次类推。现在,给定两个整数n和m,0n=m=200,你的程序要计算第n个素数到第m个素数之间所有的素数的和,包括第n个素数和第m个素数。输入格式:两个整数,第一个表示n,第二个表示m。输出格式:一个整数,表示第n个素数到第m个素数之间所有的素数的和,包括第n个素

19、数和第m个素数。输入样例:2 4输出样例:15时间限制:500ms内存限制:32000kb#includeint main() int m=0; int n=0; int i; int j; int sum=0; int isPrime=1; int num=0; scanf(%d %d,&n,&m); for(i=2;i=20000;i+) for(j=2;j=n&num=m) sum+=i; if(num=m) break; isPrime=1;XX文库 - 让每个人平等地提升自我 printf(%dn,sum); return 0;11. 念整数题目内容:你的程序要读入一个整数,范围是-

20、100000,100000。然后,用汉语拼音将这个整数的每一位输出出来。如输入1234,则输出:1.yiersansi注意,每个字的拼音之间有一个空格,但是最后的字后面没有空格。当遇到负数时,在输出的开头加上“fu”,如-2341输出为:1.fuersansiyi输入格式:一个整数,范围是-100000,100000。输出格式:表示这个整数的每一位数字的汉语拼音,每一位数字的拼音之间以空格分隔,末尾没有空格。输入样例:-30输出样例:fu san ling时间限制:500ms内存限制:32000kb#include int main() int x; int num; scanf(%d,&x)

21、; int length=0; int onum; int numbit=1; int numbox; if(x9) num/=10; length+; while(length0) numbit*=10; length-; num=onum; while(numbit0) numbox=num/numbit; switch(numbox) case 0: printf(ling); break; case 1: printf(yi); break; case 2: printf(er); break; case 3: printf(san); break; case 4: printf(si

22、); break; case 5: printf(wu); break; case 6: printf(liu); break; case 7: printf(qi); break; case 8: printf(ba); break; case 9: printf(jiu); break; default: printf(error); num%=numbit; numbit/=10; if(numbit0) printf( ); else printf(n); return 0;#include #define ARRAY_SIZE 200int main(void) int i, a,

23、b, integer_part; char resultARRAY_SIZE + 1 = 0; /* 存放小数部分 */ scanf(%d/%d, &a, &b); integer_part = a / b; /* 商的整数部分 */ a = a % b; /* 余数 */ for( i = 0; i ARRAY_SIZE; +i) a *= 10; /* 余数乘以10作为下一轮计算的被除数 */ resulti = ( a / b ) + 0;/* 得到一位商 */ a %= b; /* 新余数 */ if(a = 0) break; resulti + 1 = 0; printf(%d.%sn, integer_part, result); return 0;

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1