二级 C 语言笔试-12

一、选择题
1. 软件是指 A) 程序 B) 程序和文档 C) 算法加数据结构 D) 程序、数据与相关文档的完整集合
2. 下面不属于软件设计原则的是 A) 抽象 B) 模块化 C) 白底向上 D) 信息隐蔽
3. 树是结点的集合,它的根结点的数目是( )。 A) 有且只有 1 个 B) 1 或多于 1 C) 0 或 1 D) 至少有 2 个
4. 下列叙述中正确的是______。 A) 一个算法的空间复杂度大,则其时间复杂度也必定大 B) 一个算法的空间复杂度大,则其时间复杂度必定小 C) 一个算法的时间复杂度大,则其空间复杂度必定小 D) 上述三种说法都不对
5. 对长度为 n 的线性表进行顺序查找,在最坏的情况下需要比较的次数为( )。 A) 125 B) n/2 C) n D) n+1
6. 对如下二叉树 进行后序遍历的结果为( )。 A.ABCDEF B.DBEAFC C.ABDECF D.DEBFCA

7. 下列叙述中正确的是______。 A) 程序的执行效率与数据的存储结构密切相关 B) 程序的执行效率只取决于程序的控制结构 C) 程序的执行效率只取决于所处理的数据量 D) 以上三种说法都不对
8. 软件详细设计产生的图如图所示,该图是 A) N-S 图 B) PAD 图 C) 程序流程图 D) E-R 图
9. 在 Windows 环境下,若资源管理器左窗口中的某文件夹左边标有“+”标记,则表示______。 A) 该文件夹为空 B) 该文件夹中含有子文件夹 C) 该文件夹中只包含有可执行文件 D) 该文件夹中包含系统文件
10. 为了提高软件模块的独立性,模块之间最好是( )。 A) 控制耦合 B) 公共耦合 C) 内容耦合 D) 数据耦合
11. 结构化程序有 3 种基本结构组成,3 种基本结构组成的算法______。 A) 可以完成任何复杂的任务 B) 只能完成部分复杂的任务 C) 只能完成符合结构化的任务 D) 只能完成一些简单的任务

12. 以下选项中,能用作数据常量的是______。 A) 0115 B) 0118 C) 1.5e1.5 D) 115L
13. 以下选项中,不能作为合法常量的是 A) 1.234e04 B) 1.234e0.4 C) 1.234e+4 D) 1.234e0
14. 有以下程序: main() int i=10,j=1; printf("%d,%d\n",i--,++j);
执行后的输出结果是 ______。 A) 9,2 B) l0,2 C) 9,1 D) 10,1
15. 下列表达式中,可以正确表示或的关系是( )。 A) (x>=1)10(x<=0) B) x>1‖x=0 C) x>=1 ORx<=0 D) X>=1&&x<=0
16. 若有语句:char*line[5];,以下叙述中正确的是 A) 定义 line 是一个数组,每个数组元素是一个基类型为 char 的指针变量 B) 定义 line 是一个指针变量,该变量可以指向一个长度为 5 的字符型数组 C) 定义 line 是一个指针数组,语句中的。号称为间址运算符 D) 定义 line 是一个指向字符型函数的指针
17. 若变量都已正确说明,则以下程序段输出结果为( )。 #include<stdio.h> main() char a='a'; int b=2; printf(a>b?”***a=%d":"###b=%d",a,b);
A) ***a=3 B) ###b=3 C) ***a=3##b=5 D) 全部错误

18. 若变量 a,i 已正确定义,且 i 已正确赋值,下面合法的语句是( )。 A) a==1 B) ++i; C) a=a++=5; D) a=int(i);
19. 已知字母 A 的 ASCII 代码值为 65,若变量 kk 为 char 型,以下不能正确判断出比中的 值为大写字母的表达式是
A) kk>='A'&&kk<='Z' B) !(kk>='A'||kk<='Z') C) (kk+32)>='a'&&(kk+32)<='z' D) isalpha(kk)&&(kk<91)
20. 在下列选项中,没有构成死循环的是 A) int i=100; B) for(::); while(1) i=i%100+1: if(i>100)break;
C) int k=10000; dok++;while(k>10000); D) int s=36: while(s)--s;
21. 以下程序的输出结果是( )。 main() int a[3][3]=1,2),3,4),5,6),i,j,s=0; for(i=1;i<3;i++) for(j=0;j<=i;j++)s+=a[i][j]; printf("%d\n",s);
A.18 B.19 C.20 D.21
22. 已定义下列函数: int fun(int *p) return *p;) fun 函数返回值是( )。 A) 不确定的值 B) 一个整数 C) 形参 p 中存放的值 D) 形参 p 的地址值
23. 下面程序的运行结果是 #include<stdio.h> main() int a=28,b;

char s[10],*p; p=s; dob=a%16; if(b<10) *p=b+48; else*p=b+55; p++;a=a/5;while(a>0); *p='\0';puts(s); A) 10 B) C2 C) C51 D) \0
24. 以下程序段完全正确的是 A) int *P; scanf("%d", &p); B) int *P; scanf("%d", p); C) int k, *P=&k; scanf("%d", p); D) int k, *P; *P=&k; scanf("%d", p);
25. 有以下程序(说明:字母 A 的 ASCII 码值是 65) #include<stdio.h> void fun(char *s) while(*s) if(*s%2) printf ("%c", *s); s++;
main() char a[]="BYTE"; fun(a); printf("\n");
程序运行后的输出结果是______。 A) BY B) BT C) YT D) YE
26. 以理程序的输出结果______。 main() char st[20]="he11\O\t\\"; printf("%d%d\n",str1en(st),sizeof(st));
A) 99 B) 520 C) 1320 D) 2020
27. 下列叙述中正确的是 A) 定义函数时,形参的类型说明可以放在函数体内 B) return 后边的值不能为表达式 C) 如果函数值的类型与返回值类型不一致,以函数值类型为准 D) 如果形参与实参类型不一致,以实参类型为准

28. 有以下程序: main() int a[4][4]=1,4,3,2,,8,6,5,7,,3,7,2,5,,4,8,6,1,),i,j,k,t; for(i=0;i<4;i++) for(j=0;j<3;j++) for(k=j+1;k<4;k++) if(a[j][i]>a[k][i])t=a[j][i];a[j][i]=a[k][i];a[k][i]=t;/*按列排序*/ for(i=0;i<4;i++)printf("%d,",a[i][i]);
程序运行后的输出结果是______。 A) 1,6,5,7, B) 8,7,3,1, C) 4,7,5,2, D) 1,6,2,1,
29. 以下程序运行后的输出结果是 #define F(X,Y)(X) * (Y) main( ) int a=3,b=4; printf("%d\n",F(a++,b++)); A) 12 B) 15 C) 16 D) 20
30. 有以下程序 #include void f(char p[][10],int n)
char t[10];int i,j; for(i=0;i<N-1;i++) for(j=i+1;j<N;j++) if(strcmp(p[i],p[j])>0)
strcpy(t,p[i]);strcpy(p[i],p[j]);strcpy(p[j],t);
main() char p[5][10]="abc", "aabdfg", "abbd", "dedbe", "cd";
f(p,5); printf("%d\n", strlen(p[0])); 程序运行后的输出结果是______。 (A) 2 (B) 4 (C) 6 (D) 3
31. 以下程序的输出结果是______。

struct HAR int x,y;struct HAR*p;h[2]; main()
h[0].x=1;h[0].y=2; h[1].x=3;h[1].y=4; h[0].p=&h[1];h[1].p->y); printf("%d%d\n",(h[0].p)->x,(h[1].p)->y);
A) 12 B) 23 C) 14 D) 32
32. 分析下列程序: #include<stdio.h> main() int*p1,*p2,*p; int a=6,b=9; p1=&a;p2=&b; if(a<b)p=p1;p1=p2;p2=p; printf("%d,%d",*p1,*p2); printf("%d,%d",a,b);
程序的输出结果为( )。 A) 9,6 6,9 B) 6,9 9,6 C) 6,9 6,9 D) 9,6 9,6
33. 判断字符串 s1 是否大于字符串 s2,应该使用( )。 A) if(strcmp(s1,s2)<0) B) if(s1>s2) C)if(strcmp(s2,s1)<0) D) if(strcmp(s1,s2))
34. 若要求定义具有 10 个 int 型元素的一维数组 a,则以下定义语句中错误的是 A) #define N 10 int a[N]; B) #define n 5 int a[2*n]; C) int a[5+5]; D) int n=10,a[n];
35. 若有说明 int a[][3]=1,2,3,4,5,6,7,8,9,则 a 数组第一维的大小是( )。 A) 2 B) 3 C) 4 D) 无确定值

36. 有下列程序: fun(int x) int p; if(x==0‖x==1) return(3) ; p=x-fun(x-2) ; return p;
main() printf("%d\n",fun(7) ); 执行后的输出结果是( )。 A) 7 B) 3 C) 2 D) 0
37. 有以下程序: #include<string.h> main() char p[20]='a','d','c','d',q[]="abc",r[]="abcde" strcat(p,r);strcpy(p+strlen(q),q); printf("%d\n",sizeof(p)); 程序运行后的输出结果是______。 A) 9 B) 6 C) 11 D) 7
38. 下列的程序用来输出两个字符串前 7 个字符中对应相等的字符及其位置号,程序空白处 应该填写的是( )。
#include<stdio.h> main()
char s1[]="chinese",s2[]="japnese";

int i; for(i=0;sl1[i]!='\0'&&s2[i]!='\0';i++) if(s1[i]==s2[i]&&i<7) ______,

A) putchar(s2[i]);putchar(i) B) puts(s1[i],i) C) printf("%c%d\n",s2[i],i) D) printf("%c",s1[i]);printf("%d\n",i)

39. 下列程序的输出结果是( )。 point(char*pt); main() char b[4]= 'a','c','s','f ,*pt=b; pt=point(pt); printf("%c\n",*pt);

point(char*p) p+=3; return p;

A) s

B) c

C) f

D) a

40. 若运行时给变量 x 赋值 12,则以下程序的运行结果是( )。 #include<stdio.h> main() int x,y; scanf("%d",&x); y=x>12? x+10:x-12; printf("%d\n",y);
A) 0 B) 22 C) 12 D) 10

二、填空题 41. 软件定义时期主要包括______和需求分析两个阶段。

42. 在面向对象方法中,类之间共享属性和操作的机制称为

43. 软件工程三要素包括方法、工具和过程,其中, 和管理。

支持软件开发的各个环节的控制

44. 在关系模型中,把数据看成是二维表,每一个二维表称为一个______。

45. Jackson 方法是一种面向______的结构化方法。

46. 表达式(int)((double)(5/21+2.5)的值是______。

47. 以下程序段的定义语句中,x[1]的初值是______,程序运行后输出的内容是______。 #include<stdio.h> main()
int x[]=(1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16,*p[4],i; for(i=0;i<4;i++)
p[i]=&x[2*i+1]; printf("%d",p[i][0]);
printf("\n");

48. 下列程序的功能是对输入的一行字符中的数字字符的字面值累加,输出此累加和,请填 空。
#include<stdio.h> #include<ctype.h> main()
char c; int a,s=0; while(______) if(isdigit(C) ) a=c-'0';s+=a; printf("s=%d",s);

49. 有以下程序,程序执行后,输出结果是 #include<stdio.h> void fun(int*A) a[0]=a[1]; main() int a[10]=10,9,8,7,6,5,4,3,2,1,,i; for(i=2;i>1=0;i-) fun(&a[i]); for(i=0;i<10;i++) printf("%d,a[i]); printf("\\n");

50. 以下程序的输出结果是

float fun(int x,int y)

return(x+y);

main()

int a=2,b=5,c=8; printf("%3.0f\\n",fun((int)fun(a+c,b),a-c));

51. 以下程序运行后的输出结果是______。 #include char*ss(char*s) char*p,t; P=s+1;t=*s; while(*p) *(p-1)=*p;p++; *(p-1)=t; return s;
main() char*p,str[10]="abcdefgh"; p=ss(str); printf("%s\n",p);

52. 以下程序运行后的输出结果是

# include<string.h>

void fun(char *s,int p,int k)

int i; for(i=p;i<k-1;i++)s[i]=s[i+2];

main() char s[]="abcdefg"; fun(s,3,strlen(s));puts(s);
53. 设有下列程序: #include<stdio.h> #include<string.h> main() int i; chars[10],t[10]; gets(t); for(i=0;i<2;i++) gets(s); if(strcmp(t,s)<0)strcpy(t,s);
printf("%s\n",t);
程序运行后,从键盘上输入(<CR>代表回车符):CDEF<CR>BADEF<CR>QTHRG <CR>,则程序的输出结果是______。
54. 设有下列程序: #include<stdio.h> #include<string.h> main()
int i; char s[10],t[10]; gets(t); for(i=0;i<2;i++)
gets(s); if(strcmp(t,s)<0)strcpy(t,s);
printf("%s\n",t);
程序运行后,从键盘上输入(<CR>代表回车符):DEF<CR>BADEF<CR>QTHRG< CR>,则程 序的输出结果是______。
55. 常见的软件开发方法有结构化方法和面向对象方法。对某应用系统经过需求分析建立数 据流图(DFD),则应采用______方法。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/681406.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

洛谷: P9749 [CSP-J 2023] 公路

思路: 贪心思想指的是在对问题求解的时候&#xff0c;总是能做出在当前看来是最好的选择,也就是说&#xff0c;如果要得到整个问题的最优答案&#xff0c;那么要求每一步都能做出最好的选择&#xff08;feihua&#xff09;。 在这道题里面&#xff0c;我们希望在来到第i站的时…

Windows搭建docker+k8s

安装Docker Desktop 从官网下载&#xff0c;然后直接安装即可&#xff0c;过程很简单&#xff0c;一直Next就行。 有一点需要注意就是要看好对应的版本&#xff0c;因为后边涉及到版本的问题。 https://www.docker.com/products/docker-desktop 安装完成&#xff0c;双击图…

Python列表clear()方法详解与实例

Python列表clear()方法详解与实例 &#x1f335;文章目录&#x1f335; &#x1f333;引言&#x1f333;&#x1f333;clear()&#x1f333;&#x1f340;功能介绍&#x1f340;&#x1f340;语法&#x1f340;&#x1f340;示例&#x1f340;&#x1f340;注意事项&#x1f34…

go面试题--使用两个goroutine交替打印数字与字母

使用两个goroutine交替打印数字与字母 题目如下&#xff1a; 使用两个goroutine交替打印序列&#xff0c;一个goroutine打印数字&#xff0c;另外一个goroutine打印字母&#xff0c;最终效果如下&#xff1a; 12AB34CD56EF78GH910IZ1112KL1314MN1516OP1718QR1920ST2122UV2324W…

【白话前端】快速区分webGL,webGPU,unity3D和UE4

在3D图形渲染的渲染领域&#xff0c;很多友友们对上述概念傻傻分不清&#xff0c;站在前端开发角度&#xff0c;我用简单语言说下&#xff0c;结论在文章最后。 一、四者都能进行3D图形渲染 它们之间有一些区别&#xff0c;下面我将对它们进行简单的区分&#xff1a; WebGPU&a…

探索设计模式的魅力:捕捉变化的风-用观察者模式提升用户体验

设计模式专栏&#xff1a;http://t.csdnimg.cn/U54zu 目录 一、引言 核心概念 应用场景 可以解决的问题 二、场景案例 2.1 不用设计模式实现 2.2 存在问题 2.3 使用设计模式实现 2.4 成功克服 三、工作原理 3.1 结构图和说明 3.2 工作原理详解 3.3 实现步骤 四、 优…

TCP 和 UDP的区别

文章目录 概述区别UDPTCPTCP与UDP的选择UDP和TCP编程区别 概述 TCP&#xff08;Transmission Control Protocol&#xff0c;传输控制协议&#xff09;和 UDP&#xff08;User Datagram Protocol&#xff0c;用户数据报协议&#xff09;是互联网中两种最常用的传输层协议 总的来…

C++笔记:容器适配器:优先级队列(priority_queue)模拟实现

文章目录 框架(constructor)size()、empty()、top()push()声明参数实现代码 pop()声明实现代码 仿函数与函数指针仿函数的定义仿函数实现回调函数指针实现回调adjust_up 和 adjust_down 的改进 完整代码 容器适配器&#xff08;Container Adapter&#xff09;是一种 C 中的抽象…

【每日一题】牛客网——链表的回文结构

✨专栏&#xff1a;《Java SE语法》 | 《数据结构与算法》 | 《C生万物》 ❤️感谢大家点赞&#x1f44d;&#x1f3fb;收藏⭐评论✍&#x1f3fb;&#xff0c;您的三连就是我持续更新的动力❤️ &#x1f64f;小杨水平有限&#xff0c;欢迎各位大佬指点&#xff0c;相互学习…

Leetcode 718 最长重复子数组

题意理解&#xff1a; 给两个整数数组 nums1 和 nums2 &#xff0c;返回 两个数组中 公共的 、长度最长的子数组的长度 。 如&#xff1a; nums1 [1,2,3,2,1], nums2 [3,2,1,4,7] 则最长重复子序列为&#xff1a; 321 长度为3 这里采用动态规划解决这个问题。最长公共子序…

centos7更新yum安装docker-ce使用阿里源

centos7更新yum安装docker-ce使用阿里源 centos7更新yum安装docker-ce使用阿里源240209版 #!/bin/bash ## 卸载之前的docke sudo yum remove docker \docker-client \docker-client-latest \docker-common \docker-latest \docker-latest-logrotate \docker-logrotate \dock…

OpenCV-38 图像金字塔

目录 一、图像金字塔 1. 高斯金字塔 2. 拉普拉斯金字塔 一、图像金字塔 图像金字塔是图像中多尺度表达的一种&#xff0c;最主要用于图像的分割&#xff0c;是一种以多分辨率来解释图像的有效但概念简单的结构。简单来说&#xff0c;图像金字塔是同一图像不同分辨率的子图…

2000-2021年县域指标统计数据库

2000-2021年县域统计数据库 1、时间&#xff1a;2000-2021年 2、来源&#xff1a;县域统计年鉴 3、范围&#xff1a;2500县 5、指标&#xff1a; 地区名称、年份、行政区域代码、所属城市、所属省份、行政区域土地面积平方公里、乡及镇个数个、乡个数个、镇个数个、街道办…

2024.2.6 模拟实现 RabbitMQ —— 数据库操作

目录 引言 选择数据库 环境配置 设计数据库表 实现流程 封装数据库操作 针对 DataBaseManager 单元测试 引言 硬盘保存分为两个部分 数据库&#xff1a;交换机&#xff08;Exchange&#xff09;、队列&#xff08;Queue&#xff09;、绑定&#xff08;Binding&#xff0…

调用讯飞火星AI大模型WebAPI

调用讯飞火星AI大模型 记录一次调用讯飞AI大模型的过程 官方文档 首先&#xff0c;去官网申请资格&#xff0c;获得必要秘钥等 再编写url&#xff0c;该url存在编码要求&#xff0c;具体看官网url编写 具体代码如下&#xff1a; getWebsocketUrl() {return new Promise((resol…

vivado仿真时使用的代码与实际不一致的解决办法

前言 在使用仿真软件时经常会遇到实际需要时间较长&#xff0c;而仿真需要改写实际代码运行时间的问题&#xff0c;在vivado软件中找到了解决办法 代码部分 这里使用一个最简单的例子来说明一下&#xff0c;学过FPGA的朋友肯定可以看出来就是一个简单的计数器使LED每500ms交…

使用Express 构建高效的Web应用程序

一、使用环境变量管理配置信息 在开发Web应用程序时&#xff0c;通常需要配置信息&#xff0c;例如数据库连接字符串、API密钥等。为了安全起见&#xff0c;我们建议将这些敏感信息存储在环境变量中&#xff0c;而不是硬编码在应用程序代码中。Express.js提供了process.env对象…

力扣:53. 最大子数组和

解题思路&#xff1a; 1.先把数组为空和数组的长度为1时的特殊情况分别开来。声明一个sum变量用于计算数组中的连续子数组的总和值 。在声明一个guo变量用于一种接收sum中的前i-1的总和。另一种接收sum中前i的总和&#xff0c;主要根据sum的值来判断是接收的哪一种。在声明一个…

【MySQL】:分组查询、排序查询、分页查询、以及执行顺序

&#x1f3a5; 屿小夏 &#xff1a; 个人主页 &#x1f525;个人专栏 &#xff1a; MySQL从入门到进阶 &#x1f304; 莫道桑榆晚&#xff0c;为霞尚满天&#xff01; 文章目录 &#x1f4d1;前言一. 分组查询1.1 语法1.2 where与having区别1.3 注意事项:1.4 案例: 二. 排序查询…

LRU Cache

目录 一、认识LRU Cache 二、LRU Cache实现 一、认识LRU Cache LRU是Least Recently Used的缩写&#xff0c;意思是最近最少使用&#xff0c;是一种Cache替换算法 狭义的Cache指的是位于CPU和主存间的快速RAM&#xff0c; 通常它不像系统主存那样使用DRAM技术&#xff0c;而…