最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 正文

经典练习C语言编程的题目与答案整理

来源:动视网 责编:小OO 时间:2025-10-02 03:23:01
文档

经典练习C语言编程的题目与答案整理

1.逆序输出正三位数#includeintmain(){intinput,output=0;scanf("%d",&input);while(input!=0){output=output*10+input%10;input/=10;}printf("%d\\n",output);return0;}2.百元找零函数#includeintmain(){请输入金额(元)");请输入票面");找您%d元。\\n",change);}3.求平均数#includeintmain(){doublec=(a
推荐度:
导读1.逆序输出正三位数#includeintmain(){intinput,output=0;scanf("%d",&input);while(input!=0){output=output*10+input%10;input/=10;}printf("%d\\n",output);return0;}2.百元找零函数#includeintmain(){请输入金额(元)");请输入票面");找您%d元。\\n",change);}3.求平均数#includeintmain(){doublec=(a
1.逆序输出正三位数

#include

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

int main()

{

 请输入金额(元)");

 请输入票面");

 找您%d元。\\n",change);

}

3.求平均数

#include

int main()

{

double c=(a+b)/2.0;

/*    scanf("%d",&amount); 

 这是注释,我随便放的,没意义

 和%d的平均值是%f\\n",a,b,c);

}

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

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

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

int main()

{

 int rs;

 scanf("%d",&rs);

if(rs % 10 != 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("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。

这里的计算可以用下面的表格来表示:

数字342315
数位654321
数字奇偶
数位奇偶
奇偶一致001101
二进制位值32168421
按照二进制位值将1的位的位值加起来就得到了结果13。

你的程序要读入一个非负整数,整数的围是[0,100000],然后按照上述算法计算出表示奇偶性的那个二进制数字,输出它对应的十进制值。

提示:将整数从右向左分解,数位每次加1,而二进制值每次乘2。

输入格式:

一个非负整数,整数的围是[0,100000]。

输出格式:

一个整数,表示计算结果。

输入样例:

342315

输出样例:

13

#include "stdio.h"

#include "math.h"//使用pow函数需要引用

int main()

{

 :输入的正整数;ret:结果

  数位;num:个位数;binary:二进制位值;

             int cont=1,num,binary=1;

             do

             {

   等到个位上的数

   判断奇偶一致性

                  {

                       if(cont!=1)

     :幂次方函数,表示2的3次方

    相加每一位奇偶一致的二进制位值,得到十进制数

   去掉个位上的数

                   cont++;

             }while( number>0 );

        return 0;    

}

9. 奇偶个数

题目容:

你的程序要读入一系列正整数数据,输入-1表示输入结束,-1本身不是输入的数据。程序输出读到的数据中的奇数和偶数的个数。

输入格式:

一系列正整数,整数的围是(0,100000)。如果输入-1则表示输入结束。

输出格式:

两个整数,第一个整数表示读入数据中的奇数的个数,第二个整数表示读入数据中的偶数的个数。两个整数之间以空格分隔。

输入样例:

9 3 4 2 5 7 -1

输出样例:

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,0输入格式:

两个整数,第一个表示n,第二个表示m。

输出格式:

一个整数,表示第n个素数到第m个素数之间所有的素数的和,包括第n个素数和第m个素数。

输入样例:

2 4 

输出样例:

15

时间:500ms存:32000kb

#include

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++){

  }

  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

 

int main()

{

 

 

 

}

#include

#define ARRAY_SIZE 200

int main(void) {

  存放小数部分 */ 

 商的整数部分 */ 

  余数 */

  余数乘以10作为下一轮计算的被除数 */

     result[i] = ( a / b ) + '0';/* 得到一位商 */

  新余数 */

     if(a == 0)

      break; 

     }

     result[i + 1] = '\\0';

     printf("%d.%s\\n", integer_part, result);

     return 0;

}

文档

经典练习C语言编程的题目与答案整理

1.逆序输出正三位数#includeintmain(){intinput,output=0;scanf("%d",&input);while(input!=0){output=output*10+input%10;input/=10;}printf("%d\\n",output);return0;}2.百元找零函数#includeintmain(){请输入金额(元)");请输入票面");找您%d元。\\n",change);}3.求平均数#includeintmain(){doublec=(a
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top