




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、1.逆序输出正三位数#include <stdio.h>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 <stdio.h>int main()int amount=100; int price=0;printf("请输入金额(元)");
2、scanf("%d",&price); printf("请输入票面");scanf("%d",&amount); int change=amount-price;printf("找您%d元。n",change);return 0;3.求平均数#include <stdio.h>int main()int a,b;scanf("%d %d",&a,&b); double c=(a+b)/2.0;/*scanf("%d",&am
3、ount); 这是注释,我随便放的,没意义int change=amount-price;*/printf("%d和%d的平均值是%fn",a,b,c);return 0;4.写出程序的输出:int i=1; switch ( i/3 ) case 0: printf("zero"); case 1: printf("one"); case 2: printf("two"); 正确答案是:zeroonet
4、wo。5.水仙花数是指一个N位正整数(N>=3),它的每个位上的数字的N次幂之和等于它本身。例 如:153 = 13 + 53+33。 本题要求编写程序,计算所有N位水仙花数。输入格式:输入在一行中给出一个正整数N(3<=N<=7)。输出格式:按递增顺序输出所有N位水仙花数,每个数字占一行。输入样例:3输出样例:153370371407#include <stdio.h>int main(void) int i, j, n, low = 1, high, temp, sum, item, remainder;scanf("%d", &
5、amp;n);for(i = 1; i < n; +i)low *= 10;/* 得到n位数的下限 */high = low * 10;/* 得到n位数的上限 */for(i = low; i < high; +i) temp = i;sum = 0;while(temp > 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
6、0;6.时间换算UTC是世界协调时,BJT是北京时间,UTC时间相当于BJT减去8。现在,你的程序要读入一个整数,表示BJT的时和分。整数的个位和十位表示分,百位和千位表示小时。如果小时小于10,则没有千位部分;如果小时是0,则没有百位部分;如果分小于10分,需要保留十位上的0。如1124表示11点24分,而905表示9点5分,36表示0点36分,7表示0点7分。有效的输入范围是0到2359,即你的程序不可能从测试服务器读到0到2359以外的输入数据。你的程序要输出这个时间对应的UTC时间,输出的格式和输入的相同,即输出一个整数,表示UTC的时和分。整数的个位和十位表示分,百位和千位表示小时。
7、如果小时小于10,则没有千位部分;如果小时是0,则没有百位部分;如果分小于10分,需要保留十位上的0。提醒:要小心跨日的换算。输入格式:一个整数,表示BJT的时和分。整数的个位和十位表示分,百位和千位表示小时。如果小时小于10,则没有千位部分;如果小时是0,则没有百位部分;如果分小于10分,需要保留十位上的0。输出格式:一个整数,表示UTC的时和分。整数的个位和十位表示分,百位和千位表示小时。如果小时小于10,则没有千位部分;如果小时是0,则没有百位部分;如果分小于10分,需要保留十位上的0。输入样例:903输出样例:103时间限制:500ms内存限制:32000kb#include <
8、stdio.h>int main() int h,m,input,b; scanf("%d",&input); h = input/100; m = input%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) 信
9、号强度即大小.其中R位于报告第一位,共分5级,用15数字表示.· 1-Unreadable· 2-Barely readable, occasional words distinguishable· 3-Readable with considerable difficulty· 4-Readable with practically no difficulty· 5-Perfectly readable报告第二位是S,共分九个级别,用19中的一位数字表示· 1-Faint signals, barely perceptible
10、83; 2-Very weak signals· 3-Weak signals· 4-Fair signals· 5-Fairly good signals· 6-Good signals· 7-Moderately strong signals· 8-Strong signals· 9-Extremely strong signals现在,你的程序要读入一个信号报告的数字,然后输出对应的含义。如读到59,则输出:Extremely strong signals, perfectly
11、readable.输入格式:一个整数,信号报告。整数的十位部分表示可辨度,个位部分表示强度。输入的整数范围是11,59,这个范围外的数字不可能出现在测试数据中。输出格式:一句话,表示这个信号报告的意义。按照题目中的文字,先输出表示强度的文字,跟上逗号和空格,然后是表示可辨度的文字,跟上句号。注意可辨度的句子的第一个字母是小写的。注意这里的标点符号都是英文的。输入样例:33输出样例:Weak signals, readable with considerable difficulty.#include <stdio.h>int mai
12、n() int 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("Fa
13、ir signals,"); break; case 5: printf("Fairly goodsignals,"); break; case 6: printf("Good signals,"); break; case 7: printf("Moderately strongsignals,"); break; case 8: printf("Strong signals,"); break; case 9: printf("Extremely strongsignals,");
14、 break; switch(r) case 1: printf("unreadable."); break; case 2: printf("barely readable,occasional words distinguishable."); break; case 3: printf("readable withconsiderable difficulty."); break; case 4: printf("readable withpractically no difficulty."); break
15、; case 5: printf("perfectly readable."); break; return 0; 也可以写成下面这样:#include <stdio.h>int main() int s; int r; int n; scanf("%d",&n); r=n/10; s=n%10;
16、 switch(s) case 0:printf(""); case 1:printf("Faint signals, barely perceptible, ");break; case 2:printf("Very weak signals, ");break;
17、160; case 3:printf("Weak signals, ");break; case 4:printf("Fair signals, ");break; case 5:printf("Fairly good signals, ");break; case 6:printf(&quo
18、t;Good signals, ");break; case 7:printf("Moderately strong signals, ");break; case 8:printf("Strong signals, ");break; case 9:printf("Extremely strong signals,
19、 ");break; switch(r) case 0:printf(""); case 1:printf("unreadable.");break; case 2:printf("barely readable, occasional wor
20、ds distinguishable.");break; case 3:printf("readable with considerable difficulty.");break; case 4:printf("readable with practically no difficulty.");break; case 5:
21、printf("perfectly readable.");break; return 0;8. 数字特征值题目内容:对数字求特征值是常用的编码算法,奇偶特征是一种简单的特征值。对于一个整数,从个位开始对每一位数字编号,个位是1号,十位是2号,以此类推。这个整数在第n位上的数字记作x,如果x和n的奇偶性相同,则记下一个1,否则记下一个0。按照整数的顺序把对应位的表示奇偶性的0和1都记录下来,就形成了一个二进制数字。比如,对于342315,这个二进制数字就是001101。这里的计算可以用下面的表格来表示
22、:数字342315数位654321数字奇偶奇偶偶奇奇奇数位奇偶偶奇偶奇偶奇奇偶一致001101二进制位值32168421按照二进制位值将1的位的位值加起来就得到了结果13。你的程序要读入一个非负整数,整数的范围是0,100000,然后按照上述算法计算出表示奇偶性的那个二进制数字,输出它对应的十进制值。提示:将整数从右向左分解,数位每次加1,而二进制值每次乘2。输入格式:一个非负整数,整数的范围是0,100000。输出格式:一个整数,表示计算结果。输入样例:342315输出样例:13#include "stdio.h"#include "math.h"/使
23、用pow函数需要引用int main() /number:输入的正整数;ret:结果 int number=-1,ret=0; scanf("%d",&number); if(number>0 && number<=100000) /cont:数位;num:个位数;binary:二进制位值; int cont=1,num,binary=1; do num=number%10;/等到个位上的数 if(num%2=0 && cont%2=0) | (num%2=1 && cont%2=1)/判断奇偶一致性 if
24、(cont!=1) binary=pow(2,cont-1);/pow(2,3):幂次方函数,表示2的3次方 ret += binary;/相加每一位奇偶一致的二进制位值,得到十进制数 number/=10;/去掉个位上的数 cont+; while( number>0 ); printf("%d",ret); return 0; 9. 奇偶个数题目内容:你的程序要读入一系列正整数数据,输入-1表示输入结束,-1本身不是输入的数据。程序输出读到的数据中的奇数和偶数的个数。输入格式:一系列正整数,整数的范围是(0,100000)。如果输入-1则表示输入结束。输出格式:两
25、个整数,第一个整数表示读入数据中的奇数的个数,第二个整数表示读入数据中的偶数的个数。两个整数之间以空格分隔。输入样例:9 3 4 2 5 7 -1输出样例:4 2#include <stdio.h>int main() int a,i=0,j=0; do scanf("%d",&a); if(a%2=1) i+; if(
26、a%2=0) j+; while(a!=-1); printf("%d %d",i,j); return 0;10. 素数和题目内容:我们认为2是第一个素数,3是第二个素数,5是第三个素数,依次类推。现在,给定两个整数n和m,0<n<=m<=200,你的程序要计算第n个素数到
27、第m个素数之间所有的素数的和,包括第n个素数和第m个素数。输入格式:两个整数,第一个表示n,第二个表示m。输出格式:一个整数,表示第n个素数到第m个素数之间所有的素数的和,包括第n个素数和第m个素数。输入样例:2 4 输出样例:15时间限制:500ms内存限制:32000kb#include<stdio.h>int 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<=
28、20000;i+) for(j=2;j<i;j+) if(i%j)=0) isPrime=0; break; if(isPrime=1) num+; if(num>=n&&num<=m) sum+=i; if(num=m) break; isPrime=1; printf("%dn",sum); return 0;11. 念整数题目内容:你的程序要读入一个整数,范围是-100000,100000。然后,用汉语拼音将这个整数的每一位输出出来。如输入1234,则输出:1. yi er san si注意,每个字的拼音
29、之间有一个空格,但是最后的字后面没有空格。当遇到负数时,在输出的开头加上“fu”,如-2341输出为:1. fu er san si yi输入格式:一个整数,范围是-100000,100000。输出格式:表示这个整数的每一位数字的汉语拼音,每一位数字的拼音之间以空格分隔,末尾没有空格。输入样例:-30输出样例:fu san ling时间限制:500ms内存限制:32000kb#include<stdio.h> int main() int x; int num; scanf("%d",&x); int length=0; int onum; int numbit=1; int numbox; if(x<0) printf("fu "); num=-x; else num=x; onum=num; while(num>9) num/=10; length+; while(length>0) numbit*=10; length-; num=onum; while(numbit>0) numbox=num/numbit; switch(nu
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 【房屋租赁合同】街面房出租合同4篇
- 2025年装修泥水工程承包合同2篇
- 7技术合同非专利技术转让合同3篇
- 景观设计总结汇报
- 大米包装设计调研报告
- 2025辽宁装备制造职业技术学院辅导员考试试题及答案
- 2025贵州医科大学辅导员考试试题及答案
- 2025贵阳幼儿师范高等专科学校辅导员考试试题及答案
- 2025萍乡卫生职业学院辅导员考试试题及答案
- 2025甘肃建筑职业技术学院辅导员考试试题及答案
- (新版)旅游接待业理论考试题库(含各题型)
- 不符合工作处理记录表
- 高管人员绩效考核方案
- xx旅游股份有限公司财务管理制度
- DB32-T 4338-2022 高速公路桥梁支座安装施工技术规范
- 直螺纹套筒进场检查记录
- Q∕GDW 12177-2021 供电服务记录仪技术规范
- 形式发票--INVOICE(跨境-)
- 某路延伸段新建市政工程施工设计方案
- 110kV变电站操作规程
- 温州市住房公积金补贴提取申请表
评论
0/150
提交评论