资源描述
1.逆序输出正三位数
#include <stdio.h>
int main()
{
int input,output= 0;
scanf("%d",&input);
while(input != 0)
{
output = output*10 + input%10;
input /= 10;
}
printf("%d\n",output);
return 0;
}
2.百元找零函数
#include <stdio.h>
int main()
{
int amount=100;
int price=0;
printf("请输入金额(元)");
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",&amount);
这是注释,我随便放的,没意义
int change=amount-price;*/
printf("%d和%d的平均值是%f\n",a,b,c);
return 0;
}
4.写出程序的输出:
int i=1;
switch ( i/3 ) {
case 0: printf("zero");
case 1: printf("one");
case 2: printf("two");
}
正确答案是:zeroonetwo。
5.水仙花数是指一个N位正整数(N>=3),它的每个位上的数字的N次幂之和等于它本身。例 如:153 = 13 + 53+33。 本题要求编写程序,计算所有N位水仙花数。
输入格式:
输入在一行中给出一个正整数N(3<=N<=7)。
输出格式:
按递增顺序输出所有N位水仙花数,每个数字占一行。
输入样例:
3
输出样例:
153
370
371
407
#include <stdio.h>
int main(void) {
int i, j, n, low = 1, high, temp, sum, item, remainder;
scanf("%d", &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("%d\n", i);
}
return 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的时和分。整数的个位和十位表示分,百位和千位表示小时。如果小时小于10,则没有千位部分;如果小时是0,则没有百位部分;如果分小于10分,需要保留十位上的0。
提醒:要小心跨日的换算。
输入格式:
一个整数,表示BJT的时和分。整数的个位和十位表示分,百位和千位表示小时。如果小时小于10,则没有千位部分;如果小时是0,则没有百位部分;如果分小于10分,需要保留十位上的0。
输出格式:
一个整数,表示UTC的时和分。整数的个位和十位表示分,百位和千位表示小时。如果小时小于10,则没有千位部分;如果小时是0,则没有百位部分;如果分小于10分,需要保留十位上的0。
输入样例:
903
输出样例:
103
时间限制:500ms内存限制:32000kb
#include <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) 信号强度即大小.
其中R位于报告第一位,共分5级,用1—5数字表示.
· 1---Unreadable
· 2---Barely readable, occasional words distinguishable
· 3---Readable with considerable difficulty
· 4---Readable with practically no difficulty
· 5---Perfectly readable
报告第二位是S,共分九个级别,用1—9中的一位数字表示
· 1---Faint signals, barely perceptible
· 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 readable.
输入格式:
一个整数,信号报告。整数的十位部分表示可辨度,个位部分表示强度。输入的整数范围是[11,59],这个范围外的数字不可能出现在测试数据中。
输出格式:
一句话,表示这个信号报告的意义。按照题目中的文字,先输出表示强度的文字,跟上逗号和空格,然后是表示可辨度的文字,跟上句号。注意可辨度的句子的第一个字母是小写的。注意这里的标点符号都是英文的。
输入样例:
33
输出样例:
Weak signals, readable with considerable difficulty.
#include <stdio.h>
int main()
{
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("Fair 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,");
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;
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;
switch(s){
case 0:printf("");
case 1:printf("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:printf("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 with 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
4
2
3
1
5
数位
6
5
4
3
2
1
数字奇偶
奇
偶
偶
奇
奇
奇
数位奇偶
偶
奇
偶
奇
偶
奇
奇偶一致
0
0
1
1
0
1
二进制位值
32
16
8
4
2
1
按照二进制位值将1的位的位值加起来就得到了结果13。
你的程序要读入一个非负整数,整数的范围是[0,100000],然后按照上述算法计算出表示奇偶性的那个二进制数字,输出它对应的十进制值。
提示:将整数从右向左分解,数位每次加1,而二进制值每次乘2。
输入格式:
一个非负整数,整数的范围是[0,100000]。
输出格式:
一个整数,表示计算结果。
输入样例:
342315
输出样例:
13
#include "stdio.h"
#include "math.h"//使用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(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则表示输入结束。
输出格式:
两个整数,第一个整数表示读入数据中的奇数的个数,第二个整数表示读入数据中的偶数的个数。两个整数之间以空格分隔。
输入样例:
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(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个素数到第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<=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("%d\n",sum);
return 0;
}
11. 念整数
题目内容:
你的程序要读入一个整数,范围是[-100000,100000]。然后,用汉语拼音将这个整数的每一位输出出来。
如输入1234,则输出:
1. yi er san si
注意,每个字的拼音之间有一个空格,但是最后的字后面没有空格。当遇到负数时,在输出的开头加上“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(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");
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(numbit>0)
{
printf(" ");
}
else
{
printf("\n");
}
}
return 0;
}
#include <stdio.h>
#define ARRAY_SIZE 200
int main(void) {
int i, a, b, integer_part;
char result[ARRAY_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作为下一轮计算的被除数 */
result[i] = ( a / b ) + '0';/* 得到一位商 */
a %= b; /* 新余数 */
if(a == 0)
break;
}
result[i + 1] = '\0';
printf("%d.%s\n", integer_part, result);
return 0;
}
展开阅读全文