C语言期中自测试卷

devtools/2024/10/9 7:05:31/

选择题

1、若有变量定义int a; double b; 要输入数据存放在a和b中,则下面正确的输入数据的语句为: 【 正确答案: C
A. scanf("%d%f",a,b);
B. scanf("%d%f",&a,&b);
C. scanf("%d%lf",&a,&b);
D. scanf("%d%lf",a,b);

2、为了避免嵌套的条件分支语句if~ else的二义性,特规定else总是与【 正确答案: A】组成配对关系。

A. 在其之前未配对的最近的if
B. 缩排位置相同的if
C. 在其前未配对的if
D. 同一行上的if

3、下面不能使字符数组获得正确字符串的操作是 【 正确答案: C】     
(A)  char s[10] = {"ABCDE"};
(B)  char s[10] = {'A', 'B', 'C', 'D', 'E'};
(C)  char s[10];  s = "ABCDE";
(D)  char s[10];  scanf("%s", s);

4、若有以下语句
int x = 3;
do {
    printf("%d\n", x -= 2);
} while (!(--x));
则上面程序段  【 正确答案: B     

(A)  输出的是1
(B)  输出的是1和-2
(C)  输出的是3和0
(D)  是死循环

5、字符串"\tabc5\0bc"的长度(不包括结束符)是  【 正确答案: D】         
(A)  9
(B)  7

(C)  6
(D)  5

6、以下正确的描述是  【 正确答案: B】    

(A)  continue语句的作用是结束整个循环的执行
(B)  break语句的作用是结束包含它的那层循环
(C)  在循环体内使用break语句或continue语句的作用相同
(D)  使用一次break语句可以从多层循环嵌套中退出

7、以下能正确表示x的取值范围在[15, 80]和[-1, -5]内的C语言表达式为 【 正确答案: A】。
A.(x>=-5)&&(x<=-1)||(x>=15)&&(x<=80)
B.(x<=-5)||(x>=-1) &&(x<=15)||(x>=80)
C.(-1>=x>=-5)||(15<=x<=80)
D.(x<=-1)&&(x>=-1)&&(x<=15)&&(x<=80)

8、若有说明:int a[][3] = {2,3,1,5,7,8,7,9,4}; 则a数组第一维的大小是 【 正确答案: B】。
A.2               B.3              C.4             D.不确定值

9、以下程序的运行结果正确的是 【 正确答案: C】。

#include <stdio.h>

int  main( )

unsigned char a = 8, c;

c = a>>3;

printf("%d\n",c);

       return 0;

}

A.32         B.16           C.1              D.0

10、引用数组元素时,数组下标的数据类型允许是 【 正确答案: C
A.整型常量                                     B.整型表达式

C.整型常量、整型表达式均可          D.任何类型

填空题

1、以下程序段中循环执行次数为                 【 正确答案: 死循环 或 无限循环】。(X次或死循环)

int k = 1;

while(!k==0)

{

    k = k+1;

    printf("%d\n",k);

}

2、下面程序段的运行结果是                  【 正确答案: 600】        
char ch[ ] = "600";
int a, s = 0;
for (a = 0; ch[a] >= '0' && ch[a] <= '9'; a++)
    s = 10 * s + ch[a] - '0';
printf("%d", s);

3、以下程序的运行结果是                  【 正确答案: 4578

#include<stdio.h>
int main()
{
    int i;
    for (i=4;i<10;i++)
    {
        if (i%3==0)
            continue;
        printf("%d",i);
    }
}

4、C语言中,若有定义:int a[10]; 则该数组能访问的下标下限为            【 正确答案: 0】,上限为             【 正确答案: 9】。

5、已知:int a=5,b=6,w=1,x=2,y=3,z=4;执行语句“(a=w>x)&&(b=y>z);”后b 的值为            【 正确答案: 6

编程题

1、同构数

【问题描述】

具有下面性质的数a称为"同构数":设b是a的平方,a与b的低若干位相同。例如,5是25的同构数,25是625的同构数.编程序满足如下要求:
输入两个整数a,b (0<=a, b<=99),找出a、b之间全部的同构数。
【输入形式】

控制台输入0-99之间的两个整数a和b.
【输出形式】

控制台上按照由小到大的顺序输出所有同构数.每一个整数占一行.
【样例输入】

0 30

【样例输出】

0
1
5
6
25

【样例说明】

在0-30之间的同构数有0, 1, 5, 6, 25.

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <math.h>
int main()
{int a,b,x,y,i;scanf("%d %d",&a,&b);for(i=a;i<=b;i++){x=i;y=x*x;if(i<10&&y%10==x){printf("%d\n",i);}if(i>=10&&y%100==x){printf("%d\n",i);}}return 0;
}

2、二维数组处理

【问题描述】有一个4*4的整型二维数组组成的矩阵,元素值从键盘输入。现要求:

(1)找出其中最大数和最小数,并打印其所在的行号和列号

(2)求对角线元素之和

(3)求此矩阵的转置矩阵

(4)求此矩阵最外围所有元素之和

【输入形式】

按行输入4*4矩阵各元素的值
【输出形式】

最大数及所在的行号和列号

最小数及所在的行号和列号

主对角线元素之和,副对角线元素之和

转置矩阵(按行输出)(%5d形式)

矩阵最外围所有元素之和
【样例输入】

34 53 135 46

678 54 567 5

123 4 67 54

123 56 7 8

【样例输出】

max:678 row:2 col:1

min:4 row:3 col:2

163,740

transport matrix:

   34  678  123  123

   53   54    4   56

  135  567   67    7

   46    5   54    8

sum=1322

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <math.h>
int main()
{int a[4][4];int i,j,max,min,sum=0,sum1=0,sum2=0,a1=0,a2=0,a3=0,a4=0;for(i=0;i<4;i++){for(j=0;j<4;j++){scanf("%d",&a[i][j]);}}max=a[0][0];min=a[0][0];for(i=0;i<4;i++){for(j=0;j<4;j++){if(max<a[i][j]){max=a[i][j];a1=i;a2=j;}if(min>a[i][j]){min=a[i][j];a3=i;a4=j;}if(i==j){sum1+=a[i][j];}if(i+j==3){sum2+=a[i][j];}if(i==0||i==3){sum+=a[i][j];}}}sum=sum+a[1][0]+a[2][0]+a[1][3]+a[2][3];printf("max:%d row:%d col:%d\n\n",max,a1+1,a2+1);printf("min:%d row:%d col:%d\n\n",min,a3+1,a4+1);printf("%d,%d\n\n",sum1,sum2);printf("transport matrix:\n\n");for(i=0;i<4;i++){for(j=0;j<4;j++){printf("%5d",a[j][i]);}printf("\n\n");}printf("sum=%d\n",sum);return 0;
}

3、分数化简

【问题描述】

编写程序,从控制台读入一个分数的分子和分母(分数无符号,并且分子小于分母,其大小不会超过int数据类型的表示范围),输出化简后分子和分母不含公约数的分数。

【输入形式】

从控制台输入两个正整数分别表示分子和分母,两整数之间以一个空格分隔。

【输出形式】

在标准输出上输出化简后的分子和分母,以一个空格分隔。

【输入样例1】

26664 479952

【输出样例1】

1 18

【样例1说明】

输入的分子为26664,分母为479952,分母可以被分子整除,输出化简后的分子为1,分母为18。

【输入样例2】

9 24

【输出样例2】

3 8

【样例2说明】

输入的分子为9,分母为24,化简后分子和分母分别为3和8,不含公约数。

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <math.h>
int main()
{int a,b,i;scanf("%d %d",&a,&b);for(i=b;i>=1;i--){if(a%i==0&&b%i==0){break;}}printf("%d %d\n",a/i,b/i);return 0;
}

4、sinx计算公式

【问题描述】

已知sinx的近似计算公式如下:

 sin x = x - x3/3! + x5/5! - x7/7! + ... + (-1)n-1x2n-1/(2n-1)!

 其中x为弧度,n为正整数。编写程序根据用户输入的x和n的值,利用上述近似计算公式计算sinx的近似值,要求输出结果小数点后保留7位

【输入形式】

从控制台输入小数x(0<=x<=20)和整数n(1<=n<=5000),两数中间用空格分隔。

【输出形式】

控制台输出公式结果:小数点后保留7位。

【样例输入1】

0.5236 4

【样例输出1】

0.5000011

【样例输入2】

0.5236 50

【样例输出2】

0.5000011

【样例说明】

输入x为0.5236,n为4,求得sinx近似计算公式的值为0.5000011,小数点后保留7位;同样,输入x为0.5236,n为50,求得sinx近似计算公式的值为0.5000011,小数点后保留7位。

注意:为保证数据的准确性和一致性,请使用double数据类型保存计算结果

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <math.h>
int main()
{double x,s=0,a=1;int n,i,j,z=0;scanf("%lf %d",&x,&n);for(i=1;i<=2*n-1;i+=2){a=1;for(j=1;j<=i;j++){a*=j;if(j==i){s+=pow(-1.0,z)*pow(x,i)/a;z++;}}}printf("%.7f\n",s);return 0;
}

 5、工资

【问题描述】
假设税前工资和税率如下(s代表税前工资,t代表税率):
s<1000    t=0%
1000<=s<2000      t=10%
2000<=s<3000  t=15%
3000<=s<4000     t=20%
4000<=s             t=25%
编写一程序,要求用户输入税前工资额,然后用switch语句计算税后工资额。
【输入形式】
从键盘输入税前工资s,可以是浮点数。
【输出形式】
输出税后工资额,保留小数后两位。
【输入样例】

3000

【输出样例】

2400.00

【样例说明】
税前工资为3000,所以税率为20%,扣除税后工资为2400.00

#define _CRT_SECURE_NO_WARNINGS
#include <stdio.h>
#include <math.h>
int main()
{double a,b,s;scanf("%lf",&s);b=s;s=s/1000;switch((int)s){case 0:a=b;break;case 1:a=b*0.9;break;case 2:a=b*0.85;break;case 3:a=b*0.8;break;default:a=b*0.75;break;}printf("%.2f\n",a);return 0;
}

程序片段编程题

1、程序填空:输出m到n之间的所有素数

【问题描述】下面的程序输出m到n之间的所有素数。 
【输入形式】两个正整数m n
【输出形式】m~n之间的素数
【样例输入】

20 40
【样例输出】

  23   29   31   37

#include <stdio.h>
int main()
{int i,j;int m, n;scanf("%d%d", &m, &n);for( i=m; i<=n; i++){for( j=2; j<=i-1; j++)if(i%j==0) break;if(j==i)printf("%4d ",i);}return 0;
}

2、十进制转换为十六进制

【问题描述】下面的函数itoh(n,s)完成将无符号十进制整数转换成十六进制表示,并存入字符串数组s中。程序中用到的函数reverse(char s[])是一个将字符串置逆的函数。

【输入形式】一个无符号整数
【输出形式】对应的十六进制数
【样例输入】255
【样例输出】FF

#include <stdio.h>
#include <string.h>
void reverse(char s[]);//函数声明 
void itoh(unsigned n,char s[]) {int h,i=0;do {h=n%16;		s[i]=(h<=9)?h+'0':h+'A'-10;i++;} while((n/=16)!=0);s[i]='\0';	reverse(s);
}
void reverse(char s[]) {int temp,i,j;for(i=0,j=strlen(s)-1; i<j; i++,j--) {temp=s[i];s[i]=s[j];s[j]=temp;}
}
int main()
{char s[50];unsigned n;scanf("%d",&n);itoh(n,s);  //调用函数实现转换 printf("%s\n",s);return 0;} 

3、学生成绩统计

【问题描述】从键盘输入若干个学生成绩,统计并输出最高分、最低分和平均分,输入-1时结束。
【输入形式】若干个学生成绩
【输出形式】最高分、最低分和平均分
【样例输入】

78 90 87 82 78 76 79 -1

【样例输出】

max:90.00,min:76.00,avg:81.43

#include <stdio.h>
int main()
{float score, max,min,sum;int cnt = 0;sum=0;scanf("%f", &score);max = min = score;while(score!=-1){sum += score;if (max<score)max = score;if (min>score)min = score;cnt++;scanf("%f", &score);		}printf("max:%.2f,min:%.2f,avg:%.2f\n",max, min, sum/cnt);return 0;
}


http://www.ppmy.cn/devtools/123252.html

相关文章

2024Selenium自动化常见问题!

"NoSuchElementException"异常&#xff1a; 确保使用了正确的选择器来定位元素。可以使用id、class、XPath或CSS选择器等。 可以尝试使用find_elements方法来查找元素列表&#xff0c;并检查列表的长度来判断元素是否存在。 使用显式等待&#xff08;WebDriverWait…

【Redis】持久化(下)-- AOF

文章目录 AOF概念如何使用AOFAOF工作流程命令写入演示文件同步策略 AOF的重写机制概念触发重写机制AOF重写流程 启动时数据恢复混合持久化总结 AOF 概念 AOF持久化:以独立日志的方式记录每次的写命令,重启时再重新执行AOF文件中的命令达到恢复数据的目的.AOF的主要作用是解决…

【路径规划】基于球面向量的粒子群优化算法(SPSO)

摘要 本文提出了一种基于球面向量的粒子群优化算法&#xff08;Spherical Vector-based Particle Swarm Optimization, SPSO&#xff09;用于解决路径规划问题。该算法通过球面坐标系表示粒子的位置更新&#xff0c;增强了搜索空间的探索能力和全局优化性能。通过与遗传算法&a…

看门狗电路设计

看门狗电路设计 看门狗是什么应用架构图TPV6823芯片功能硬件时序图为什么要一般是要保持200个毫秒左右的这种低电平的时间看门狗电路实际应用与条件 看门狗是什么 硬件看门狗芯片&#xff0c;Watch DogTimer&#xff0c;可用于受到电气噪音、电源故障、静电放电等影响(造成软件…

CloudStack计算节点配置

主机信息 CloudStack计算节点 任务1、计算节点基础环境准备 1)需要创建2张网卡&#xff01;&#xff01;&#xff01;】 2)VMware Workstation 中设置网卡模式为NAT&#xff0c;在“网络编辑器”中设置DHCP&#xff0c;网关设置为192.168.100.1&#xff0c;地址段为192.168.…

用AI构建小程序需要多久?效果如何?

随着移动互联网的快速发展&#xff0c;多端应用的需求日益增长。为了提高开发效率、降低成本并保证用户体验的一致性&#xff0c;前端跨端技术在如今的开发界使用已经非常普遍了&#xff0c;技术界较为常用的跨端技术有小程序技术、HTML5技术两大类。 2023年以来&#xff0c;伴…

Python标准库之Logging库

logging——Python的日志记录工具 当前版本&#xff1a;3.12.6 记录日期&#xff1a;2024.10.08 官方文档&#xff1a;https://docs.python.org/zh-cn/3/library/logging.html 这个模块为应用与库实现了灵活的事件日志系统的函数与类。 共包含4个模块&#xff1a; 记录器&a…

PyQt入门指南九 网络通信基础

在PyQt应用程序中实现网络通信通常涉及使用Python的标准库socket或第三方库如requests进行HTTP请求。以下是一些基本的网络通信概念和如何在PyQt应用程序中实现它们的指导。 网络通信基础 网络通信主要涉及客户端和服务器之间的数据交换。客户端发送请求&#xff0c;服务器处…