【C语言】C语言题库【附源码+持续更新】

这篇具有很好参考价值的文章主要介绍了【C语言】C语言题库【附源码+持续更新】。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

欢迎来到英杰社区https://bbs.csdn.net/topics/617804998

目录

 文章来源地址https://www.toymoban.com/news/detail-851293.html

1、练习2-1 Programming in C is fun!

2、练习2-3 输出倒三角图案

3、练习2-4 温度转换

4、练习2-6 计算物体自由下落的距离

5、练习2-8 计算摄氏温度

6、练习2-9 整数四则运算

7、练习2-10 计算分段函数[1]

8、练习2-11 计算分段函数[2]

9、练习2-12 输出华氏-摄氏温度转换表

10、练习2-13 求N分之一序列前N项和

11、练习2-14 求奇数分之一序列前N项和

12、练习2-15 求简单交错序列前N项和

13、练习2-17 生成3的乘方表

14、练习2-18 求组合数

15、习题2-1 求整数均值

16、习题2-2 阶梯电价

17、习题2-3 求平方与倒数序列的部分和

18、习题2-4 求交错序列前N项和

19、习题2-5 求平方根序列前N项和

20、习题2-6 求阶乘序列前N项和

21、练习3-2 计算符号函数的值

22、练习3-4 统计字符

23、练习3-5 输出闰年

24、练习3-7 成绩转换

25、练习3-8 查询水果价格

26、习题3-1 比较大小

27、习题3-2 高速公路超速处罚

28、习题3-3 出租车计价

29、习题3-4 统计学生成绩

30、习题9-1 时间换算

31、习题9-3 平面向量加法

32、习题9-4 查找书籍

33、习题9-5 通讯录排序

34、练习4-6 猜数字游戏

35、练习4-7 求e的近似值

36、练习4-10 找出最小值

37、练习4-11 统计素数并求和

38、习题4-1 求奇数和

39、习题4-2 求幂级数展开的部分和

40、习题4-3 求分数序列前N项和

41、习题4-4 特殊a串数列求和

42、习题4-6 水仙花数

43、习题4-7 最大公约数和最小公倍数

44、习题7-5 找鞍点

45、练习5-1 求m到n之和

46、练习5-2 找两个数中最大者

47、练习5-3 数字金字塔

48、习题5-1 符号函数

49、习题5-2 使用函数求奇数和

50、习题5-3 使用函数计算两点间的距离


 

1、练习2-1 Programming in C is fun!

本题要求编写程序,输出一个短句“Programming in C is fun!”。

输入格式:

本题目没有输入。

输出格式:

在一行中输出短句“Programming in C is fun!”。

代码:

#include<stdio.h>
int main()
{
  printf("Programming in C is fun!\n");

}

2、练习2-3 输出倒三角图案

本题要求编写程序,输出指定的由“*”组成的倒三角图案。

输入格式:

本题目没有输入。

输出格式:

按照下列格式输出由“*”组成的倒三角图案。

* * * *
* * *
* *
*

代码:

#include<stdio.h>
int main()
{
  printf("* * * *\n");
  printf(" * * *\n");
  printf("  * *\n");
  printf("   *\n");
  return 0;
}

3、练习2-4 温度转换

本题要求编写程序,计算华氏温度150°F对应的摄氏温度。计算公式:C=5×(F−32)/9,式中:C表示摄氏温度,F表示华氏温度,输出数据要求为整型。

输入格式:

本题目没有输入。

输出格式:

按照下列格式输出

fahr = 150, celsius = 计算所得摄氏温度的整数值

代码:

#include<stdio.h>
int main()
{
  int F=150;
  printf("fahr = 150, celsius = %d\n",5*(F-32)/9);
}

4、练习2-6 计算物体自由下落的距离

一个物体从100米的高空自由落下。编写程序,求它在前3秒内下落的垂直距离。设重力加速度为10米/秒 ^2^。

输入格式:

本题目没有输入。

输出格式:

按照下列格式输出

height = 垂直距离值

结果保留2位小数。

代码:

#include<stdio.h>
#include<math.h>
int main()
{
  int g=10;
  int t=3;
  printf("height = %.2lf\n",(double)(g/2*(int)pow(t,2)));
}

 

5、练习2-8 计算摄氏温度

给定一个华氏温度F,本题要求编写程序,计算对应的摄氏温度C。计算公式:C=5×(F−32)/9。题目保证输入与输出均在整型范围内。

输入格式:

输入在一行中给出一个华氏温度。

输出格式:

在一行中按照格式“Celsius = C”输出对应的摄氏温度C的整数值。

输入样例:

150

输出样例:

Celsius = 65

代码:

#include<stdio.h>
int main()
{
  int c;
  scanf("%d\n",&c);
  printf("Celsius = %d\n",5*(c-32)/9);
}

6、练习2-9 整数四则运算

本题要求编写程序,计算2个正整数的和、差、积、商并输出。题目保证输入和输出全部在整型范围内。

输入格式:

输入在一行中给出2个正整数A和B。

输出格式:

在4行中按照格式“A 运算符 B = 结果”顺序输出和、差、积、商。

输入样例:

3 2

输出样例:

3 + 2 = 5 3 - 2 = 1 3 * 2 = 6 3 / 2 = 1

代码:

#include<stdio.h>
int main()
{
  int m,n;
  scanf("%d %d\n",&m,&n);
  if(n!=0){
  printf("%d + %d = %d\n",m,n,m+n);
  printf("%d - %d = %d\n",m,n,m-n);
  printf("%d * %d = %d\n",m,n,m*n);
  printf("%d / %d = %d\n",m,n,m/n);
  }
  return 0;
}

7、练习2-10 计算分段函数[1]

本题目要求计算下列分段函数f(x)的值:

【C语言】C语言题库【附源码+持续更新】,C语言项目,算法,c++,c语言,数据结构

输入格式:

输入在一行中给出实数x。

输出格式:

在一行中按“f(x) = result”的格式输出,其中x与result都保留一位小数。

输入样例1:

10

输出样例1:

f(10.0) = 0.1

输入样例2:

0

输出样例2:

f(0.0) = 0.0

代码:

#include<stdio.h>

int main()
{
  double x;
  scanf("%lf\n",&x);
  if(x==0) printf("f(%.1lf) = %.1lf\n",x,x);
  else printf("f(%.1lf) = %.1lf\n",x,1/x);
  return 0;
}

8、练习2-11 计算分段函数[2]

本题目要求计算下列分段函数f(x)的值:

【C语言】C语言题库【附源码+持续更新】,C语言项目,算法,c++,c语言,数据结构

注:可在头文件中包含 math.h ,并调用 sqrt 函数求平方根,调用 pow 函数求幂。

输入格式:

输入在一行中给出实数x。

输出格式:

在一行中按“f(x) = result”的格式输出,其中x与result都保留两位小数。

输入样例1:

10

输出样例1:

f(10.00) = 3.16

输入样例2:

-0.5

输出样例2:

f(-0.50) = -2.75

代码:

#include<stdio.h>
#include<math.h>
int main()
{
  double x;
  scanf("%lf\n",&x);
  if(x>=0) printf("f(%.2lf) = %.2lf\n",x,pow(x,0.5));
  else printf("f(%.2lf) = %.2lf\n",x,pow(x+1,2)+2.0*x+1/x);
  return 0;
}

9、练习2-12 输出华氏-摄氏温度转换表

输入2个正整数lower和upper(lower≤upper≤100),请输出一张取值范围为[lower,upper]、且每次增加2华氏度的华氏-摄氏温度转换表。

温度转换的计算公式:C=5×(F−32)/9,其中:C表示摄氏温度,F表示华氏温度。

输入格式:

在一行中输入2个整数,分别表示lower和upper的值,中间用空格分开。

输出格式:

第一行输出:"fahr celsius"

接着每行输出一个华氏温度fahr(整型)与一个摄氏温度celsius(占据6个字符宽度,靠右对齐,保留1位小数)。

若输入的范围不合法,则输出"Invalid."。

输入样例1:

32 35

输出样例1:

fahr celsius 32 0.0 34 1.1

输入样例2:

40 30

输出样例2:

Invalid.

代码:

#include<stdio.h>
int main()
{
  int lower,upper;
  int i;
  scanf("%d %d",&lower,&upper);
  if(lower<=upper)
    {
      printf("fahr celsius\n");
      for(i=lower;i<=upper;i+=2)
      {
        printf("%d%6.1lf\n",i,(double)(5.0*(i-32)/9.0));
      }
    }
    else printf("Invalid.\n");
  return 0;
}

 

10、练习2-13 求N分之一序列前N项和

本题要求编写程序,计算序列 1 + 1/2 + 1/3 + ... 的前N项之和。

输入格式:

输入在一行中给出一个正整数N。

输出格式:

在一行中按照“sum = S”的格式输出部分和的值S,精确到小数点后6位。题目保证计算结果不超过双精度范围。

输入样例:

6

输出样例:

sum = 2.450000

代码:

#include<stdio.h>

int main()
{
  int n;
  scanf("%d",&n);
  int i;
  double sum=0.0;
  for(i=1;i<=n;i++)
  {
    sum+=1.0/i;
  }
  printf("sum = %.6lf\n",sum);
  return 0;
}

 

11、练习2-14 求奇数分之一序列前N项和

本题要求编写程序,计算序列 1 + 1/3 + 1/5 + ... 的前N项之和。

输入格式:

输入在一行中给出一个正整数N。

输出格式:

在一行中按照“sum = S”的格式输出部分和的值S,精确到小数点后6位。题目保证计算结果不超过双精度范围。

输入样例:

23

输出样例:

sum = 2.549541

代码:

#include<stdio.h>
int main()
{
  int n;
  scanf("%d",&n);
  int i;
  double sum=0.0;
  int d=1;
  for(i=1;i<=n;i++)
  {
    sum+=1.0/d;
    d+=2;
  }
  printf("sum = %.6lf\n",sum);
  return 0;
}

12、练习2-15 求简单交错序列前N项和

本题要求编写程序,计算序列 1 - 1/4 + 1/7 - 1/10 + ... 的前N项之和。

输入格式:

输入在一行中给出一个正整数N。

输出格式:

在一行中按照“sum = S”的格式输出部分和的值S,精确到小数点后三位。题目保证计算结果不超过双精度范围。

输入样例:

10

输出样例:

sum = 0.819

代码:

#include<stdio.h>
int main()
{
  int n;
  int l=1;
  scanf("%d",&n);
  int i;
  double sum=0.0;
  int d=1;
  for(i=1;i<=n;i++)
  {
    sum+=1.0/d*l;
    d+=3;
    l=-l;
  }
  printf("sum = %.3lf\n",sum);
  return 0;
}

13、练习2-17 生成3的乘方表

输入一个非负整数n,生成一张3的乘方表,输出3^​0^~3^​n^的值。可调用幂函数计算3的乘方。

输入格式:

输入在一行中给出一个非负整数n。

输出格式:

按照幂的递增顺序输出n+1行,每行格式为“pow(3,i) = 3的i次幂的值”。题目保证输出数据不超过长整型整数的范围。

输入样例:

3

输出样例:

pow(3,0) = 1 pow(3,1) = 3 pow(3,2) = 9 pow(3,3) = 27

代码:

#include<stdio.h>
#include<math.h>
int main()
{
  int n;
  scanf("%d",&n);
  int i;
  for(i=0;i<=n;i++)
  {
    printf("pow(3,%d) = %d\n",i,(int)pow(3,i));
  }
  return 0;
}

14、练习2-18 求组合数

本题要求编写程序,根据公式C ~n~^​m^=​m!(n−m)!​n! 算出从n个不同元素中取出m个元素(m≤n)的组合数。

建议定义和调用函数fact(n)计算n!,其中n的类型是int,函数类型是double。

输入格式:

输入在一行中给出两个正整数m和n(m≤n),以空格分隔。

输出格式:

按照格式“result = 组合数计算结果”输出。题目保证结果在double类型范围内。

输入样例:

2 7

输出样例:

result = 21

代码:

#include<stdio.h>

double fun(int n)
{
    int i;

    double t=1.0;

    for(i=1;i<=n;i++)
    {
        t*=i;
    }
    return t;
}
int main()
{
    int m,n;
    scanf("%d %d",&m,&n);
    double result=fun(n)/(fun(m)*fun(n-m));
    printf("result = %.0lf\n",result);
}

 

15、习题2-1 求整数均值

本题要求编写程序,计算4个整数的和与平均值。题目保证输入与输出均在整型范围内。

输入格式:

输入在一行中给出4个整数,其间以空格分隔。

输出格式:

在一行中按照格式“Sum = 和; Average = 平均值”顺序输出和与平均值,其中平均值精确到小数点后一位。

输入样例:

1 2 3 4

输出样例:

Sum = 10; Average = 2.5

代码:

#include<stdio.h>
int main()
{
  int a1,a2,a3,a4;
  scanf("%d %d %d %d",&a1,&a2,&a3,&a4);
  printf("Sum = %d; Average = %.1lf\n",a1+a2+a3+a4,(double)(a1+a2+a3+a4)/4.0);
  return 0;
}

16、习题2-2 阶梯电价

为了提倡居民节约用电,某省电力公司执行“阶梯电价”,安装一户一表的居民用户电价分为两个“阶梯”:月用电量50千瓦时(含50千瓦时)以内的,电价为0.53元/千瓦时;超过50千瓦时的,超出部分的用电量,电价上调0.05元/千瓦时。请编写程序计算电费。

输入格式:

输入在一行中给出某用户的月用电量(单位:千瓦时)。

输出格式:

在一行中输出该用户应支付的电费(元),结果保留两位小数,格式如:“cost = 应付电费值”;若用电量小于0,则输出"Invalid Value!"。

输入样例1:

10

输出样例1:

cost = 5.30

输入样例2:

100

输出样例2:

cost = 55.50

代码:

#include<stdio.h>
int main()
{
    int n;
    scanf("%d",&n);
    if(n<=50)
    {
        if(n<0) printf("Invalid Value!\n");
        else printf("cost = %.2lf\n",n*0.53);
    }
    else printf("cost = %.2lf\n",(50*0.53)+(n-50)*(0.53+0.05));
    return 0;
}

17、习题2-3 求平方与倒数序列的部分和

本题要求对两个正整数m和n(m≤n)编写程序,计算序列和m^2^+1/m+(m+1)^​2^+1/(m+1)+⋯+n^2^+1/n。

输入格式:

输入在一行中给出两个正整数m和n(m≤n),其间以空格分开。

输出格式:

在一行中按照“sum = S”的格式输出部分和的值S,精确到小数点后六位。题目保证计算结果不超过双精度范围。

输入样例:

5 10

输出样例:

sum = 355.845635

代码:

#include<stdio.h>
int main()
{
    int m,n;
    scanf("%d %d",&m,&n);
    int i;
    if(m<=n&&m!=0&&n!=0){
        double sum=0.0;
        for(i=m;i<=n;i++)
        {
            sum+=(double)pow(i,2)+1.0/i;
        }
        printf("sum = %.6lf\n",sum);
    }
    return 0;
}

 

18、习题2-4 求交错序列前N项和

本题要求编写程序,计算交错序列 1-2/3+3/5-4/7+5/9-6/11+... 的前N项之和。

输入格式:

输入在一行中给出一个正整数N。

输出格式:

在一行中输出部分和的值,结果保留三位小数。

输入样例:

5

输出样例:

0.917

代码:

#include<stdio.h>
int main()
{
    int n;
    scanf("%d",&n);
    int i;
    if(n!=0){
    double sum=0.0;
    int t1=1;
    int t2=1;
    int temp=1;
    for(i=1;i<=n;i++)
    {
        sum+=((double)t1/t2)*temp;
        t1++;
        t2+=2;
        temp=-temp;
    }
    printf("%.3lf\n",sum);}
    return 0;
}

19、习题2-5 求平方根序列前N项和

本题要求编写程序,计算平方根序列1+2+3+⋯的前N项之和。可包含头文件math.h,并调用sqrt函数求平方根。

输入格式:

输入在一行中给出一个正整数N。

输出格式:

在一行中按照“sum = S”的格式输出部分和的值S,精确到小数点后两位。题目保证计算结果不超过双精度范围。

输入样例:

10

输出样例:

sum = 22.47

代码:

#include<stdio.h>
#include<math.h>
int main()
{
    int n;
    scanf("%d",&n);
    int i;
    //if(n!=0){
    double sum=0.0;
    for(i=1;i<=n;i++)
    {
        sum+=sqrt((double)i);
    }
    printf("sum = %.2lf\n",sum);
    //}
    return 0;
}

20、习题2-6 求阶乘序列前N项和

本题要求编写程序,计算序列 1!+2!+3!+⋯ 的前N项之和。

输入格式:

输入在一行中给出一个不超过12的正整数N。

输出格式:

在一行中输出整数结果。

输入样例:

5

输出样例:

153

代码:

#include<stdio.h>
#include<math.h>
int main()
{
    int n;
    scanf("%d",&n);
    int i;
    //if(n!=0){
    long long sum=0;
    for(i=1;i<=n;i++)
    {
        sum+=fun(i);
    }
    printf("%lld\n",sum);

    //}
    return 0;
}
int fun(int n)
{
    int i;
    long long t=1;
    for(i=1;i<=n;i++)
    {
        t=t*i;
    }
   // printf("t=%lld\n",t);
    return t;
}

21、练习3-2 计算符号函数的值

对于任一整数n,符号函数sign(n)的定义如下:

【C语言】C语言题库【附源码+持续更新】,C语言项目,算法,c++,c语言,数据结构

请编写程序计算该函数对任一输入整数的值。

输入格式:

输入在一行中给出整数n。

输出格式:

在一行中按照格式“sign(n) = 函数值”输出该整数n对应的函数值。

输入样例1:

10

输出样例1:

sign(10) = 1

输入样例2:

0

输出样例2:

sign(0) = 0

输入样例3:

-98

输出样例3:

sign(-98) = -1

代码:

#include<stdio.h>
int main()
{
  int n;
  scanf("%d",&n);
  if(n>=0)
  {
    if(n>0) printf("sign(%d) = 1\n",n);
    else printf("sign(%d) = 0\n",n);
  }
  else printf("sign(%d) = -1\n",n);
}

22、练习3-4 统计字符

本题要求编写程序,输入10个字符,统计其中英文字母、空格或回车、数字字符和其他字符的个数。

输入格式:

输入为10个字符。最后一个回车表示输入结束,不算在内。

输出格式:

在一行内按照

letter = 英文字母个数, blank = 空格或回车个数, digit = 数字字符个数, other = 其他字符个数

的格式输出。

输入样例:

aZ & 09 Az

输出样例:

letter = 4, blank = 3, digit = 2, other = 1

代码:

#include<stdio.h>
int main()
{
    char str[10];
    int i;
    int letter=0;
    int blank=0;
    int digit=0;
    int other=0;
    for(i=0;i<10;i++)
    {
       scanf("%c",&str[i]);
       if(str[i]>='a'&&str[i]<='z'||str[i]>='A'&&str[i]<='Z') letter++;
       else if(str[i]==' '||str[i]=='\n') blank++;
       else if(str[i]>='0'&&str[i]<='9') digit++;
       else other++;
    }
    printf("letter = %d, blank = %d, digit = %d, other = %d\n",letter,blank,digit,other);
    return 0;
}

 

23、练习3-5 输出闰年

输出21世纪中截止某个年份以来的所有闰年年份。注意:闰年的判别条件是该年年份能被4整除但不能被100整除、或者能被400整除。

输入格式:

输入在一行中给出21世纪的某个截止年份。

输出格式:

逐行输出满足条件的所有闰年年份,即每个年份占一行。输入若非21世纪的年份则输出"Invalid year!"。若不存在任何闰年,则输出“None”。

输入样例1:

2048

输出样例1:

2004 2008 2012 2016 2020 2024 2028 2032 2036 2040 2044 2048

输入样例2:

2000

输出样例2:

Invalid year!

代码:

#include<stdio.h>
int main()
{
  int n;
  scanf("%d",&n);
  if(n>=2001&&n<=2100)
  {
    int temp=0;
    int i;
    for(i=2001;i<=n;i++)
    {
      if((i%4==0&&i%100!=0)||i%400==0)
      {printf("%d\n",i);temp++;}
    }
    if(temp==0) printf("None\n");
  }
  else
  printf("Invalid year!\n");
  return 0;
}

24、练习3-7 成绩转换

本题要求编写程序将一个百分制成绩转换为五分制成绩。转换规则:

  • 大于等于90分为A;
  • 小于90且大于等于80为B;
  • 小于80且大于等于70为C;
  • 小于70且大于等于60为D;
  • 小于60为E。

输入格式:

输入在一行中给出一个整数的百分制成绩。

输出格式:

在一行中输出对应的五分制成绩。

输入样例:

90

输出样例:

A

代码:

#include<stdio.h>
int main()
{
  int n;
  scanf("%d",&n);
  if(n>=90) 
    printf("A\n");
  else
  {
    if(n>=80) 
        printf("B\n");
    else
    {
      if(n>=70)
         printf("C\n");
      else
      {
        if(n>=60) 
            printf("D\n");
        else 
            printf("E\n");
      }
    }
  }
}

25、练习3-8 查询水果价格

给定四种水果,分别是苹果(apple)、梨(pear)、桔子(orange)、葡萄(grape),单价分别对应为3.00元/公斤、2.50元/公斤、4.10元/公斤、10.20元/公斤。

首先在屏幕上显示以下菜单:

[1] apple [2] pear [3] orange [4] grape [0] exit

用户可以输入编号1~4查询对应水果的单价。当连续查询次数超过5次时,程序应自动退出查询;不到5次而用户输入0即退出;输入其他编号,显示价格为0。

输入格式:

输入在一行中给出用户连续输入的若干个编号。

输出格式:

首先在屏幕上显示菜单。然后对应用户的每个输入,在一行中按格式“price = 价格”输出查询结果,其中价格保留两位小数。当用户连续查询次数超过5次、或主动输入0时,程序结束。

输入样例1:

3 -1 0 2

输出样例1:

[1] apple [2] pear [3] orange [4] grape [0] exit price = 4.10 price =0.00

输入样例2:

1 2 3 3 4 4 5 6 7 8

输出样例2:

[1] apple [2] pear [3] orange [4] grape [0] exit price = 3.00 price =2.50 price = 4.10 price = 4.10 price = 10.20

代码:

#include<stdio.h>
int main()
{
    int n;
    int arr[1000];
    int i=0;
    while(scanf("%d",&arr[i])!=EOF&&arr[i]!=0)
    {
        i++;
    }
    int t=i;
    printf("[1] apple\n");
    printf("[2] pear\n");
    printf("[3] orange\n");
    printf("[4] grape\n");
    printf("[0] exit\n");
    int l=1;
    for(i=0;i<t;i++)
    {
       if(arr[i]!=0&&l<=5)
       {
           if(arr[i]==1) printf("price = 3.00\n");
           else if(arr[i]==2) printf("price = 2.50\n");
           else if(arr[i]==3) printf("price = 4.10\n");
           else if(arr[i]==4) printf("price = 10.20\n");
           else  printf("price = 0.00\n");
           l++;
       }
    }
    return 0;
}

 

26、习题3-1 比较大小

本题要求将输入的任意3个整数从小到大输出。

输入格式:

输入在一行中给出3个整数,其间以空格分隔。

输出格式:

在一行中将3个整数从小到大输出,其间以“->”相连。

输入样例:

4 2 8

输出样例:

2->4->8

代码:

#include<stdio.h>
int main()
{
    int arr[3];
    scanf("%d %d %d",&arr[0],&arr[1],&arr[2]);
    int i;
    int index;
    int temp;
    int j;
    for(i=0;i<2;i++)
    {
        index=i;
        temp=arr[i];
        for(j=i+1;j<3;j++)
        {
           if(arr[j]<=arr[index]) index=j;
        }
        arr[i]=arr[index];
        arr[index]=temp;
    }
    printf("%d->%d->%d\n",arr[0],arr[1],arr[2]);
    return 0;
}

27、习题3-2 高速公路超速处罚

按照规定,在高速公路上行使的机动车,达到或超出本车道限速的10%则处200元罚款;若达到或超出50%,就要吊销驾驶证。请编写程序根据车速和限速自动判别对该机动车的处理。

输入格式:

输入在一行中给出2个正整数,分别对应车速和限速,其间以空格分隔。

输出格式:

在一行中输出处理意见:若属于正常行驶,则输出“OK”;若应处罚款,则输出“Exceed x%. Ticket 200”;若应吊销驾驶证,则输出“Exceed x%. License Revoked”。其中x是超速的百分比,精确到整数。

输入样例1:

65 60

输出样例1:

OK

输入样例2:

110 100

输出样例2:

Exceed 10%. Ticket 200

输入样例3:

200 120

输出样例3:

Exceed 67%. License Revoked

代码:

#include<stdio.h>
int main()
{
    int m; //车速
    int n; //限速
    scanf("%d %d",&m,&n);
    int t1=n+n*0.1;
    int t2=n+n*0.5;
   // printf("%d %d\n",t1,t2);
    if(m<t1) 
        printf("OK\n");
    if(m>=t1&&m<t2)
    {
        double temp1=(m-n)/(double)n*100.0;
        double temp2=temp1-(int)temp1;
        int temp;
        if(temp2>=0.5) temp=(int)temp1+1;
        else temp=(int)temp1;
        printf("Exceed %d%%. Ticket 200\n",temp);

    }

    if(m>=t2)
    {
        double temp1=(m-n)/(double)n*100.0;
        double temp2=temp1-(int)temp1;
        int temp;
        if(temp2>=0.5) temp=(int)temp1+1;
        else temp=(int)temp1;
        printf("Exceed %d%%. License Revoked\n",temp);
    }
}

28、习题3-3 出租车计价

本题要求根据某城市普通出租车收费标准编写程序进行车费计算。具体标准如下:

  • 起步里程为3公里,起步费10元;
  • 超起步里程后10公里内,每公里2元;
  • 超过10公里以上的部分加收50%的回空补贴费,即每公里3元;
  • 营运过程中,因路阻及乘客要求临时停车的,按每5分钟2元计收(不足5分钟则不收费)。

输入格式:

输入在一行中给出输入行驶里程(单位为公里,精确到小数点后1位)与等待时间(整数,单位为分钟),其间以空格分隔。

输出格式:

在一行中输出乘客应支付的车费(单位为元),结果四舍五入,保留到元。

输入样例1:

2.6 2

输出样例1:

10

输入样例2:

5.1 4

输出样例2:

14

输入样例3:

12.5 9

输出样例3:

34

代码:

#include<stdio.h>
int main()
{
    double k;
    int fen;
    scanf("%lf %d",&k,&fen);
    double money1=fen/5*2.0;
    double money2=10.0;
    double money;
    if(k<3.0) money=money1+money2;
    else
    {
        if(k<10.0) money=money1+money2+(k-3.0)*2.0;
        if(k>=10.0) money=money1+money2+(10.0-3.0)*2.0+(k-10.0)*3.0;
    }
    printf("%.0lf\n",money);
    return 0;
}

 

29、习题3-4 统计学生成绩

本题要求编写程序读入N个学生的百分制成绩,统计五分制成绩的分布。百分制成绩到五分制成绩的转换规则:

  • 大于等于90分为A;
  • 小于90且大于等于80为B;
  • 小于80且大于等于70为C;
  • 小于70且大于等于60为D;
  • 小于60为E。

输入格式:

输入在第一行中给出一个正整数N(≤1000),即学生人数;第二行中给出N个学生的百分制成绩,其间以空格分隔。

输出格式:

在一行中输出A、B、C、D、E对应的五分制成绩的人数分布,数字间以空格分隔,行末不得有多余空格。

输入样例:

7 77 54 92 73 60 65 69

输出样例:

1 0 2 3 1

代码:

#include<stdio.h>

int main()
{
    int N;
    scanf("%d",&N);
    int i;
    int arr[5]={0};
    int m;
    for(i=0;i<N;i++)
    {
        scanf("%d",&m);
        if(m>=90)arr[0]++;
        else if(m<90&&m>=80) arr[1]++;
        else if(m<80&&m>=70) arr[2]++;
        else if(m<70&&m>=60) arr[3]++;
        else arr[4]++;
    }
    for(i=0;i<5;i++)
    {
        if(i==5-1) printf("%d\n",arr[i]);
        else printf("%d ",arr[i]);
    }
    return 0;
}

 

30、习题9-1 时间换算

本题要求编写程序,以hh:mm:ss的格式输出某给定时间再过n秒后的时间值(超过23:59:59就从0点开始计时)。

输入格式:

输入在第一行中以hh:mm:ss的格式给出起始时间,第二行给出整秒数n(<60)。

输出格式:

输出在一行中给出hh:mm:ss格式的结果时间。

输入样例:

11:59:40 30

输出样例:

12:00:10

代码:

#include<stdio.h>
int main()
{
  int hh, mm, ss;
  scanf("%d:%d:%d",&hh,&mm,&ss);
  int n;
  scanf("%d",&n);
  ss = ss + n;
  mm += (ss - ss%60) > 0, ss %= 60;
  hh += (mm - mm%60) > 0, mm %= 60;
  hh %= 24;
  printf("%02d:%02d:%02d",hh,mm,ss);
  return 0;
}

 

31、习题9-3 平面向量加法

本题要求编写程序,计算两个二维平面向量的和向量。

输入格式:

输入在一行中按照“x~1~ y~1~ x~​2~ y~​2~​​ ”的格式给出两个二维平面向量v~1~=(x~1~, y~1~) 和v~2~=(x~2~ ,y~2~) 的分量。

输出格式:

在一行中按照(x, y)的格式输出和向量,坐标输出小数点后一位(注意不能输出−0.0)。

输入样例:

3.5 -2.7 -13.9 8.7

输出样例:

(-10.4, 6.0)

代码:

#include <stdio.h>
#include <math.h>
int main(){
	double x1,y1,x2,y2;
	double res1,res2;
	scanf("%lf %lf %lf %lf",&x1,&y1,&x2,&y2);
	res1=x1+x2;
	res2=y1+y2;
	if(fabs(res1)<0.05){
		res1=0.0;//如果满足则置为零
	}
	if(fabs(res2)<0.05){
		res1=0.0;
	}
	printf("(%.1f, %.1f)",res1,res2);
}

 

 

32、习题9-4 查找书籍

给定n本书的名称和定价,本题要求编写程序,查找并输出其中定价最高和最低的书的名称和定价。

输入格式:

输入第一行给出正整数n(<10),随后给出n本书的信息。每本书在一行中给出书名,即长度不超过30的字符串,随后一行中给出正实数价格。题目保证没有同样价格的书。

输出格式:

在一行中按照“价格, 书名”的格式先后输出价格最高和最低的书。价格保留2位小数。

输入样例:

3
Programming in C
21.5
Programming in VB
18.5
Programming in Delphi
25.0

输出样例:

25.00, Programming in Delphi
8.50, Programming in VB

代码:

#include <stdio.h> // 引入标准输入输出库
#include <string.h> // 引入字符串处理库
struct book{ // 定义一个结构体类型book,包含书名和价格两个成员
	char bookname[31]; // 书名,长度为31的字符数组
	double price; // 价格,浮点数类型
}ch[10]; // 定义一个结构体数组ch,包含10个book类型的元素
int main(){ // 主函数
	int n,i; // 定义整型变量n和i
	double max,min; // 定义浮点型变量max和min
	int maxi,mini; // 定义整型变量maxi和mini
	scanf("%d",&n); // 从标准输入读取一个整数,赋值给n
	getchar(); // 读取一个字符,但不使用
	for(i=0;i<n;i++){ // 循环n次
		gets(ch[i].bookname); // 从标准输入读取一行字符串,存储到ch[i].bookname中
		scanf("%lf",&ch[i].price); // 从标准输入读取一个浮点数,赋值给ch[i].price
		getchar(); // 读取一个字符,但不使用
	}
    max=min=ch[0].price; // 将ch[0].price的值赋给max和min
	maxi=mini=0; // 将0赋给maxi和mini
	for(i=1;i<n;i++){ // 循环n-1次
		if(max<ch[i].price){ // 如果ch[i].price大于max
			max=ch[i].price; // 将ch[i].price的值赋给max
			maxi=i; // 将i赋给maxi
		}
		if(min>ch[i].price){ // 如果ch[i].price小于min
			min=ch[i].price; // 将ch[i].price的值赋给min
			mini=i; // 将i赋给mini
		}
	}
	printf("%.2f, %s\n",ch[maxi].price,ch[maxi].bookname); // 打印价格最高的图书的价格和书名
	printf("%.2f, %s",ch[mini].price,ch[mini].bookname); // 打印价格最低的图书的价格和书名
}

 

 

33、习题9-5 通讯录排序

输入n个朋友的信息,包括姓名、生日、电话号码,本题要求编写程序,按照年龄从大到小的顺序依次输出通讯录。题目保证所有人的生日均不相同。

输入格式:

输入第一行给出正整数n(<10)。随后n行,每行按照“姓名 生日 电话号码”的格式给出一位朋友的信息,其中“姓名”是长度不超过10的英文字母组成的字符串,“生日”是yyyymmdd格式的日期,“电话号码”是不超过17位的数字及+、-组成的字符串。

输出格式:

按照年龄从大到小输出朋友的信息,格式同输出。

输入样例:

3
zhang 19850403 13912345678
wang 19821020 +86-0571-88018448
qian 19840619 13609876543

输出样例:

wang 19821020 +86-0571-88018448
qian 19840619 13609876543
zhang 19850403 13912345678

代码:

 

#include<stdio.h>

struct friends{
    char name[20];
    int  birth;
    char number[30];
}num[15],temp;
int main()
{
    int n,i,j;
    scanf("%d",&n);
    for(i=0; i<n; i++)
    { 
        scanf("%s",&num[i].name);
		scanf("%d",&num[i].birth);
		scanf("%s",&num[i].number )    ; 
    }
    for(i=0;i<n-1;i++)
	{
		for(j=0;j<n-1-i;j++)
		{
			if(num[j].birth>num[j+1].birth)
			{
				temp=num[j+1];
				num[j+1]=num[j];
				num[j]=temp;
			}
		}
	}
	for(i=0;i<n;i++)
	{
		printf("%s %d ",num[i].name,num[i].birth);
		puts(num[i].number);
	} 
    return 0;
}

34、练习4-6 猜数字游戏

猜数字游戏是令游戏机随机产生一个100以内的正整数,用户输入一个数对其进行猜测,需要你编写程序自动对其与随机产生的被猜数进行比较,并提示大了(“Too big”),还是小了(“Too small”),相等表示猜到了。如果猜到,则结束程序。程序还要求统计猜的次数,如果1次猜出该数,提示“Bingo!”;如果3次以内猜到该数,则提示“Lucky You!”;如果超过3次但是在N(>3)次以内(包括第N次)猜到该数,则提示“Good Guess!”;如果超过N次都没有猜到,则提示“Game Over”,并结束程序。如果在到达N次之前,用户输入了一个负数,也输出“Game Over”,并结束程序。

输入格式:

输入第一行中给出两个不超过100的正整数,分别是游戏机产生的随机数、以及猜测的最大次数N。最后每行给出一个用户的输入,直到出现负数为止。

输出格式:

在一行中输出每次猜测相应的结果,直到输出猜对的结果或“Game Over”则结束。

输入样例:

58 4
70
50
56
58
60
-2

输出样例:

Too big Too small Too small Good Guess!

代码:

#include <stdio.h>
int main(){
    // randNum:随机数  guessNum:用户猜测数  N:次数  flag:标志
    int randNum, guessNum, N, flag = 0;
    
    scanf("%d %d", &randNum, &N);
    
    for( int i=1; i<=N; i++ ){ //循环输入N次结束
        scanf("%d", &guessNum);
        
        if( guessNum < 0 )   // 输入不合法
            break;
        
        if( guessNum > randNum ) // 输入太大
            printf("Too big\n");
        else if( guessNum < randNum )  // 输入太小
            printf("Too small\n");
        else if( guessNum == randNum ){  // 相等
            if( i == 1 )  // 1次成功
                printf("Bingo!\n");
            else if( i <= 3 )  // 3次以内成功
                printf("Lucky You!\n");
            else if( i > 3 )   // 3次以上成功
                printf("Good Guess!\n");
            flag = 1;
            break;
        }
    }
    // 判断是否在N次内猜对
    if( flag == 0 )
        printf("Game Over\n");
    
    return 0;
}

 

 

35、练习4-7 求e的近似值

自然常数e可以用级数1+1/1!+1/2!+⋯+1/n!来近似计算。本题要求对给定的非负整数n,求该级数的前n项和。

输入格式:

输入第一行中给出非负整数n(≤1000)。

输出格式:

在一行中输出部分和的值,保留小数点后八位。

输入样例:

10

输出样例:

2.71828180

代码:

#include<stdio.h>
int main()
{
    int n;
    double sum=1;
    scanf("%d",&n);
    if(n<=1000)
    {
    for(int i=1;i<=n;i++)
    {
        double fart=1;
        for(int j=1;j<=i;j++)
        {
            fart=fart*j;
        }
        sum=sum+1.0/fart;
    }
    printf("%.8f",sum);
    }
    return 0;
}

 

 

36、练习4-10 找出最小值

本题要求编写程序,找出给定一系列整数中的最小值。

输入格式:

输入在一行中首先给出一个正整数n,之后是n个整数,其间以空格分隔。

输出格式:

在一行中按照“min = 最小值”的格式输出n个整数中的最小值。

输入样例:

4 -2 -123 100 0

输出样例:

min = -123

代码:

#include<stdio.h>
int main()
{
    int n = 0;
    scanf("%d", &n);
    int num = 0;
    scanf("%d", &num);
    int min = num;//最小值初始化
    for (int i = 1; i < n; i++)
    {
        scanf("%d", &num);
        if (num < min)//找到更小值
        {
            min = num;//改变最小值
        }
    }
    printf("min = %d", min);
    return 0;
}

 

37、练习4-11 统计素数并求和

本题要求统计给定整数M和N区间内素数的个数并对它们求和。

输入格式:

输入在一行中给出两个正整数M和N(1≤M≤N≤500)。

输出格式:

在一行中顺序输出M和N区间内素数的个数以及它们的和,数字间以空格分隔。

输入样例:

10 31

输出样例:

7 143

代码:

#include <stdio.h>
#include <math.h>
 
int prime(int i)
{
    int j = 0;
    for (j = 2; j <= sqrt(i); j++)
    {
        if (i % j == 0)
            return 0;
    }
    return 1;
}
 
int main()
{
    int M, N;
    int count = 0;
    int sum = 0;
    int i = 0;
    scanf("%d %d", &M, &N);
    //判断M的情况
    if(M == 1)
    {
        M++;    
        //如果M输入的是1,那么此行的作用就是使下面的for循环从2开始
    }
    //如若输入的数为0,则不符合题意,结束程序
    else if(M == 0 || N == 0)
    {
        printf("0 0");
        return 0;
    }
    for (i = M; i <= N; i++)
    {
        //利用prime()函数判断是否为素数
        if ((prime(i) == 1))
        {
            count++;
            sum = sum + i;
        }
    }
    printf("%d %d\n", count, sum);
    //10到31之间素数为:11,13,17,19,23,29,31
    return 0;
}

 

 

38、习题4-1 求奇数和

本题要求计算给定的一系列正整数中奇数的和。

输入格式:

输入在一行中给出一系列正整数,其间以空格分隔。当读到零或负整数时,表示输入结束,该数字不要处理。

输出格式:

在一行中输出正整数序列中奇数的和。

输入样例:

8 7 4 3 70 5 6 101 -1

输出样例:

116

代码:

#include <stdio.h>
int main(){
	int x;
	scanf("%d",&x);
	int sum = 0;
	while(x>0){
		if(x%2!=0){
			sum += x;
		} 
		scanf("%d",&x);
	}
	printf("%d\n",sum);
	return 0;
} 

 

 

39、习题4-2 求幂级数展开的部分和

已知函数e^x^ 可以展开为幂级数1+x+x^2^/2!+x^3^/3!+⋯+x^​k^/k!+⋯。现给定一个实数x,要求利用此幂级数部分和求e^x^的近似值,求和一直继续到最后一项的绝对值小于0.00001。

输入格式:

输入在一行中给出一个实数x∈[0,5]。

输出格式:

在一行中输出满足条件的幂级数部分和,保留小数点后四位。

输入样例:

1.2

输出样例:

3.3201

代码:

#include <stdio.h>
#include <math.h>

int main() 
{
	int k = 1, i;
	double x, item = 1, s = 1, sum = 1;
	scanf("%lf", &x);
	while(fabs(item)>=0.00001)
	{
		for(i=1; i<=k; i++)
		{
			sum *= i;
		}
		item = pow(x, k) / sum;
		s += item;
		k++;
		sum = 1;
	}
	printf("%.4f", s);
    return 0;
}    

 

 

40、习题4-3 求分数序列前N项和

本题要求编写程序,计算序列 2/1+3/2+5/3+8/5+... 的前N项之和。注意该序列从第2项起,每一项的分子是前一项分子与分母的和,分母是前一项的分子。

输入格式:

输入在一行中给出一个正整数N。

输出格式:

在一行中输出部分和的值,精确到小数点后两位。题目保证计算结果不超过双精度范围。

输入样例:

20

输出样例:

32.66

代码:

#include<stdio.h>
int main()
{
	double n;
	double sum=0;
	scanf("%lf",&n);
	int i,j,k,temp;
	j=2;
	k=1;
	for(i=1;i<=n;i++)
	{
		sum=sum+(1.0*j)/(k*1.0);
		temp=j;
		j=k+j;
		k=temp;	
	}	
	printf("%.2f",sum);
	return 0;
 } 

 

 

41、习题4-4 特殊a串数列求和

给定两个均不超过9的正整数a和n,要求编写程序求a+aa+aaa++⋯+aa⋯a(n个a)之和。

输入格式:

输入在一行中给出不超过9的正整数a和n。

输出格式:

在一行中按照“s = 对应的和”的格式输出。

输入样例:

2 3

输出样例:

s = 246

代码:

#include <math.h> 
#include <string.h>
#include <stdio.h>
double p(int a,int n)
{
	double s=a;
	for(int i=2;i<=n;i++)
	{
		s=s*10+a;
	}
	return s;
}
int main()
{
	int a,n,i;
	double s=0;
	scanf("%d %d",&a,&n);
	for(i=1;i<=n;i++)
	{
		s+=p(a,i);
	} 
	printf("s = %.0lf",s);
	return 0;
}

 

 

42、习题4-6 水仙花数

水仙花数是指一个N位正整数(N≥3),它的每个位上的数字的N次幂之和等于它本身。例如:153=1^3^+5^3^+3^3^。 本题要求编写程序,计算所有N位水仙花数。

输入格式:

输入在一行中给出一个正整数N(3≤N≤7)。

输出格式:

按递增顺序输出所有N位水仙花数,每个数字占一行。

输入样例:

3

输出样例:

153
370
371
407

代码:

#include<stdio.h>
int main()
{
	int i,n,a;
	a=1;
	
	scanf("%d",&n);
	
	for(i=1;i<n;i++){    //准备一个最小的n位数在这里就是100;
		a=a*10;
	}
	
	i=a;
	while(i<a*10){       //循环到最大的n位数为止
		int t=i;
		int sum=0;
		do{              //输出该n位数的每位的n次幂
			int d=t%10;
			t=t/10;
			int p=1;
			int j=1;
			while(j<=n){
				p=p*d;
				j++;
			}
			sum=sum+p;
		}while(t>0);
 
		if(sum == i){    //如果该n位数每位的n次幂和与该数大小相同,则为水仙花数,输出该数
			printf("%d\n",sum);
		}
		i++;
	}
	return 0;
}

 

43、习题4-7 最大公约数和最小公倍数

本题要求两个给定正整数的最大公约数和最小公倍数。

输入格式:

输入在一行中给出两个正整数M和N(≤1000)。

输出格式:

在一行中顺序输出M和N的最大公约数和最小公倍数,两数字间以1空格分隔。

输入样例:

511 292

输出样例:

73 2044

代码:

#include<stdio.h>
int main()
{
    int M,N;
    scanf("%d %d",&M,&N);
    int a,b;
    a=M;
    b=N;
    int temp;
    temp=M%N;
    while(temp)   //辗转相除法求最大公约数
    {
        M=N;
        N=temp;
        temp=M%N;
    }
    printf("%d %d\n",N,a*b/N);
    return 0;
}

 

44、习题7-5 找鞍点

一个矩阵元素的“鞍点”是指该位置上的元素值在该行上最大、在该列上最小。

本题要求编写程序,求一个给定的n阶方阵的鞍点。

输入格式:

输入第一行给出一个正整数n(1≤n≤6)。随后n行,每行给出n个整数,其间以空格分隔。

输出格式:

输出在一行中按照“行下标 列下标”(下标从0开始)的格式输出鞍点的位置。如果鞍点不存在,则输出“NONE”。题目保证给出的矩阵至多存在一个鞍点。

输入样例1:

4
1 7 4 1
4 8 3 6
1 6 1 2
0 7 8 9

输出样例1:

2 1

输入样例2:

2
1 7
4 1

输出样例2:

NONE

代码:

#include<stdio.h>
int fun1(int arr[][7],int i,int n)
{
    int j;
    int index=0;
    for(j=1;j<n;j++)
    {
        if(arr[i][j]>=arr[i][index]) index=j;
    }
    return index;
}
int fun2(int arr[][7],int i,int n)
{
    int j;
    int index=0;
    for(j=1;j<n;j++)
    {
        if(arr[j][i]<=arr[index][i]) index=j;
    }
    return index;
}
int main()
{
   int n;
   scanf("%d",&n);
   int arr[7][7];
   int i,j;
   for(i=0;i<n;i++)
   {
       for(j=0;j<n;j++)
       {
           scanf("%d",&arr[i][j]);
       }
   }
   int l=0;
   int temp1,temp2;
   for(i=0;i<n;i++)
   {
       temp1=fun1(arr,i,n);
       temp2=fun2(arr,temp1,n);
       if(arr[i][temp1]==arr[temp2][temp1])
       {
           l=1;break;
       }
   }
   if(l==1) printf("%d %d\n",temp2,temp1);
   else printf("NONE\n");
   return 0;

}

 

45、练习5-1 求m到n之和

本题要求实现一个计算m~n(m<n)之间所有整数的和的简单函数。

函数接口定义:

int sum( int m, int n );

其中m和n是用户传入的参数,保证有m<n。函数返回的是m~n之间所有整数的和。

裁判测试程序样例:

#include <stdio.h>

int max( int a, int b );//函数声明 

int main()
{    
    int a, b;

    scanf("%d %d", &a, &b);
    printf("max = %d\n", max(a, b));//调用函数,返回值给max(a,b) 

    return 0;
}


int max( int a, int b )
{
	int max;
	if(a>b)
	{
		max=a;
	}
	else
	{
		max=b;
	}
	return max;
}

 

/* 你的代码将被嵌在这里 */

输入样例:

-5 8

输出样例:

sum = 21

代码:

int sum(int m, int n)

{

    int i;

    int sum=0;

    for(i=m;i<=n;i++)

    {

        sum=sum+i;

    }

    return sum;

}

46、练习5-2 找两个数中最大者

本题要求对两个整数a和b,输出其中较大的数。

函数接口定义:

int max( int a, int b );

其中a和b是用户传入的参数,函数返回的是两者中较大的数。

裁判测试程序样例:

#include <stdio.h>

int max( int a, int b );

int main()
{    
    int a, b;
    scanf("%d %d", &a, &b);
    printf("max = %d\n", max(a, b));
    return 0;
}

/* 你的代码将被嵌在这里 */ 输入样例:

-5 8

输出样例:

max = 8

代码:

int max( int a, int b )
{
  if(a>=b)return a;
  else return b;
}

47、练习5-3 数字金字塔

本题要求实现函数输出n行数字金字塔。

函数接口定义:

void pyramid( int n );

其中n是用户传入的参数,为[1, 9]的正整数。要求函数按照如样例所示的格式打印出n行数字金字塔。注意每个数字后面跟一个空格。

裁判测试程序样例:

#include <stdio.h>

void pyramid( int n );

int main()
{    
    int n;
    scanf("%d", &n);
    pyramid(n);
    return 0;
}

 

/* 你的代码将被嵌在这里 */

输入样例:

5

输出样例:

1
2 2
3 3 3
4 4 4 4
5 5 5 5 5

代码:

void pyramid( int n )
{
    int i;
    int temp=n;
    for(i=1;i<=n;i++)
    {
        int j=1;
        for(;j<temp;j++)
           printf(" ");
        for(j=1;j<=i;j++)
        {
            printf("%d ",i);

        }
        printf("\n");
        temp--;
    }
}

48、习题5-1 符号函数

本题要求实现符号函数sign(x)。

函数接口定义:

int sign( int x );

其中x是用户传入的整型参数。符号函数的定义为:若x大于0,sign(x) = 1;若x等于0,sign(x) = 0;否则,sign(x) = −1。

裁判测试程序样例:

#include <stdio.h>

int sign( int x );

int main()
{
    int x;
    scanf("%d", &x);
    printf("sign(%d) = %d\n", x, sign(x));
    return 0;
}

 

/* 你的代码将被嵌在这里 */

输入样例:

int sign( int x )
{
  if(x>0) return 1;
  else if(x==0) return 0;
  else return -1;
}

10

输出样例:

sign(10) = 1

代码:

int sign( int x )
{
  if(x>0) return 1;
  else if(x==0) return 0;
  else return -1;
}

49、习题5-2 使用函数求奇数和

本题要求实现一个函数,计算N个整数中所有奇数的和,同时实现一个判断奇偶性的函数。

函数接口定义:

int even( int n ); int OddSum( int List[], int N );

其中函数even将根据用户传入的参数n的奇偶性返回相应值:当n为偶数时返回1,否则返回0。函数OddSum负责计算并返回传入的N个整数List[]中所有奇数的和。

裁判测试程序样例:

#include <stdio.h>
#define MAXN 10

int even( int n );

int OddSum( int List[], int N );

int main()
{    
    int List[MAXN], N, i;

    scanf("%d", &N);

    printf("Sum of ( ");

    for ( i=0; i<N; i++ ) {

        scanf("%d", &List[i]);

        if ( even(List[i])==0 )

            printf("%d ", List[i]);
    }
    printf(") = %d\n", OddSum(List, N));
    return 0;

}

/* 你的代码将被嵌在这里 */

输入样例:

6
2 -3 7 88 0 15

输出样例:

Sum of ( -3 7 15 ) = 19

代码:

int even( int n )
{

  if(n%2==0) return 1;

  else return 0;
}

int OddSum( int List[], int N )
{
  int i;

  int sum=0;

  for(i=0;i<N;i++)
  {

    if(List[i]%2!=0) sum+=List[i];

  }
  return sum;
}

50、习题5-3 使用函数计算两点间的距离

本题要求实现一个函数,对给定平面任意两点坐标(x~1~ ,y~​1~ )和(x~2~ ,y~2~),求这两点之间的距离。

函数接口定义:

double dist( double x1, double y1, double x2, double y2 );

其中用户传入的参数为平面上两个点的坐标(x1, y1)和(x2, y2),函数dist应返回两点间的距离。

裁判测试程序样例:

#include <stdio.h>
#include <math.h>
double dist( double x1, double y1, double x2, double y2 );
int main()
{    
    double x1, y1, x2, y2;
    scanf("%lf %lf %lf %lf", &x1, &y1, &x2, &y2);
    printf("dist = %.2f\n", dist(x1, y1, x2, y2));
    return 0;
}

/* 你的代码将被嵌在这里 */

输入样例:

10 10 200 100

输出样例:

dist = 210.24

代码:

double dist( double x1, double y1, double x2, double y2 )
{
  return sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2));

}

 

 

 

到了这里,关于【C语言】C语言题库【附源码+持续更新】的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 数据结构与算法解析(C语言版)--搭建项目环境

    本栏目致力于从0开始使用纯C语言将经典算法转换成能够直接上机运行的程序,以项目的形式详细描述数据存储结构、算法实现和程序运行过程。 参考书目如下:         《数据结构C语言版-严蔚敏》         《数据结构算法解析第2版-高一凡》 软件工具:         dev-cpp

    2024年02月07日
    浏览(46)
  • 考研C语言进阶题库——更新41-50题

    目录 41.编写程序要求输出整数a和b若a和b的平方和大于100,则输出a和b的平方和,否则输出a和b的和 42.现代数学的著名证明之一是Georg Cantor证明了有理数是可枚举的。他是用下面这一张表来证明这一命题的:第一项是1/1,第二项是是1/2,第三项是2/1,第四项是3/1,第五项是2/

    2024年02月11日
    浏览(32)
  • 考研C语言进阶题库——更新11-15题

    目录 11一辆以固定速度行驶的汽车,司机在上午10点看到里程表上的读数是一个对称数(即这个数从左向右读和从右向左读是完全一样的),为95859。两小时后里程表上出现了一个新的对称数。问该车的速度是多少?新的对称 12求小鸡的数量 13坤坤翁母雏 14计算1-n之间的所有奇数

    2024年02月14日
    浏览(33)
  • 考研C语言进阶题库——更新16-20题

    目录 16计算t=1+1/2+...+1/n-1+1/n 17计算1997! 18计算t=1-1÷2×2-1÷3×3-...-1÷n×n 19相传国际象棋是古印度舍罕王的宰相达依尔发明的.舍罕王十分喜爱象棋,决定让宰相自己选择何种赏赐. 这位聪明的宰相指着8*8共64格的象棋说:陛下,请您赏给我一些麦子吧. 就在棋盘的第1格放1粒,第2格放

    2024年02月14日
    浏览(35)
  • 考研C语言进阶题库——更新51-60题

    目录 51.银行系中有很多恒星,H 君晚上无聊,便爬上房顶数星星,H 君将整个银河系看做一个平面,左上角为原点(坐标为(1, 1))。现在有 n 颗星星,他给每颗星星都标上坐标(xi,yi)表示这颗星星在第 x 行,第 y 列。现在, H 君想问你 m 个问题,给你两个点的坐标(x1

    2024年02月11日
    浏览(39)
  • 考研C语言进阶题库——更新6-10题

    目录 6输入一个字符串,输出其中字母的个数 7用递归求函数值x=1,f(x)=10,x1.f(x)=f(x-1)+2 8所给字符串正序反序连接,形成新串并输出 9输入若干个整数以-1标记为结束输出其中的最大值 10求矩阵的两条对角线之和 6输入一个字符串,输出其中字母的个数 7用递归求函数值x=1,f(x)=10,

    2024年02月14日
    浏览(33)
  • 数据结构与算法期末复习——知识点+题库

    (1)数据:所有能被计算机识别、存储和处理的符号的集合(包括数字、字符、声音、图像等信息 )。 (2)数据元素:是数据的基本单位,具有完整确定的实际意义。在计算机程序中通常作为一个整体进行考虑和处理。一个数据元素可由若干个数据项组成。 (3)数据项:构成数据元

    2024年02月12日
    浏览(55)
  • 利用宝塔部署项目(持续更新)

    【方法一:解压安装】 1、https://www.oracle.com/java/technologies/downloads/ (链接拷贝于2022年03月27日) 向下找到JDK 8u321的下载列表下载.tar.gz安装包:x64 Compressed Archive,登陆后下载 2、解压到 建议使用命令解压,并记得检查下权限 3、配置环境 环境变量按需配置,多环境请修改23,

    2024年02月07日
    浏览(48)
  • 大语言模型面试问题【持续更新中】

    transformer中求和与归一化中“求和”是什么意思? 求和的意思就是残差层求和,原本的等式为y = H(x)转化为y = x + H(x),这样做的目的是防止网络层数的加深而造成的梯度消失,无法对前面网络的权重进行有效调整,导致神经网络模型退化(这种退化不是由过拟合造成的,而是

    2024年01月18日
    浏览(41)
  • 【图像融合】融合算法综述(持续更新)

    按时间顺序,综述近5年的融合算法。重点分析了最近两年的work,欢迎留言探讨 提示:以下是本篇文章正文内容,下面案例可供参考 论文:R. Wu, D. Yu, J. Liu, H. Wu, W. Chen and Q. Gu, “An improved fusion method for infrared and low-light level visible image,” 2017 14th International Computer Conference on W

    2024年02月13日
    浏览(81)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包