C++ 2022年_CSP_J_笔试题

一、单项选择题(共15题,每题2分,共计30分,每题仅有一个正确选项)

1. 以下那种功能没有涉及 C++语言面向对象特性的支持( )

AC++中调用 printf 函数

BC++中调用用户定义的类成员函数

CC++中构造一个classstruct

DC++中构造来源于同一基类的多个派生类

2. 有 6 个元素,按照 6、5、4、3、2、1 的顺序进入栈 S,请问下列哪个出栈顺序是非法的( )

A、5 4 3 6 1 2

B、4 5 3 1 2 6

C、3 4 6 5 2 1

D、2 3 4 1 5 6

3. 运行以下代码片段的行为是

int x=101;
int y=201;
int *p = &x;
int *q= &y;
p=q

A、 将x的值赋为201

B、 将y的值赋为101

C、 将q指向x的地址

D、将p指向y的地址

4. 链表和数组的区别包括( )

A、数组不能排序,链表可以。

B、链表比数组能存储更多的信息

C、数组大小固定,链表大小可以动态调整

D、以上均正确

5. 对假设栈 S和队列Q的初始状态为空。存在 e1~e6 六个互不相同的数据,每个数据按照进栈 S、出栈 S、进队列 Q、出队列 Q的顺序操作,不同数据间的操作可能会交错。已知栈 S中依次有数据 el、e2、e3、e4、e5e6 进栈,队列 Q依次有数据 e2、e4、e3、e6、e5el出队列,则栈S的容量至少是( )

A、2

B、3

C、4

D、5

6. 对表达式 a+(b-c)*d的前缀表达式为( ),其中+-*/是运算符。

A、*+a-bcd

B.+a*-bcd

`C.abc-d*+

D.abc-+d

7. 假设字母表{a,b,c,d,e}在字符串出现的频率分别为10%、15%、30%、16%、29%,若使用哈夫曼编码方式对字母进行不定长的二进制编码,字母d的编码长度为( )

A.1

B.2

C.2或3

D.3

8. 一颗有n个节点的完全二叉树用数组进行存储与表示,已知根节点存储在数组的第1个位置,若存储在数组第9个位置的结点存在兄弟节点和2个子节点,则它的兄弟节点和右子节点的位置分别为( )

A.8、18

B.10、18

C.8、19

D.10、19

9. 考虑N个顶点构成的有向连通图,采用邻接矩阵的数据结构表示时,该矩阵中至少存在( )个非零元素

A、N-1

B、N

C、N+1

D、N2

10.以下对数据结构的表述不恰当的一项为( )

A、图的深度优先遍历算法常使用的数据结构为栈

B、栈的访问原则为后进先出,队列的访问原则是先进先出

C、队列常常被用于广度优先搜索算法

D、栈与队列存在本质不同,无法用栈实现队列

11.以下哪组操作能完成在双向循环链表结点p之后插入节点s的效果(其中,next指的是节点的直接后继结点,prev指的是节点的直接前驱结点)

A.p->next->prev=s;s->prev=p;p->next=s;s->next=p->next;

B.p->next->prev=s;p->next=s;s->prev=p;s->next=p->next;

C.s->prev=p;s->next=p->next;p->next=s;p->next->prev=s;

D.s->next=p->next;p->next->prev=s;s->prev=p;p->next=s;

12.以下排序算法的常见实现中,哪个选项的说法是错误的( )

A、冒泡排序算法是稳定的

B、简单选择排序是稳定的

C、简单插入排序是稳定的

D、归并排序算法是稳定的

13. 八进制数32.1对应的十进制数是( )

A.24.125

B.24.250

C.26.125

D.26. 250

14.一个字符串中任意个连续的字符组成的子序列成为该字符串的子串,则字符串 abcab 有( )个互不相同的子串。

A.12

B.13

C.14

D.15

15.以下对递归方法的描述中,正确的是( )

A、递归是允许使用多组参数调用函数的编程技术

B、递归是通过调用自身来求解问题的编程技术

C、递归是面向对象和数据而不是功能和逻辑的编程语言模型

D、递归是将某种高级语言转换为机器代码的编程技术

二、阅读程序(程序输入不超过数组或字符串定义的范围;判断题正确填√,错误填x,除特殊说明外,判断题15分,选择题3分,共计 40分)

1.

1 #include <iostream>
2
3 using namespace std;
4
5 int main()
6  {  
7    unsigned short x,y; 
8    cin>>x>>y;
9    x=(x|x<<2) & 0x33; 
10   x=(x|x<<1) & 0x55;
11   y=(y|y << 2) & 0x33; 
12   y=(y|y<< 1) & 0x55;
13   unsigned short z=x | y << 1; 
14   cout<<z<<endl; 
15   return 0;
16 }

假设输入的 x、y 均是不超过 15 的自然数,完成下面的判断题和单选题。

  • 判断题

    1. 删去第 7 行与第 13 行的 unsigned,程序行为不变 ( )

    2. 将第 7 行与第 13 行的 short 均改为 char,程序行为不变 ( )

    3. 程序总是输出一个整数“0” ( )

    4. 当输入为“2 2” 时,输出为“10” ( )

    5. 20.当输入为“2 2”时,输出为“59” ( )

  • 选择题

    21.当输入为“13 8”时,输出为( )
    A. 0 B.209 C.197 D.226

2.

1 #include <algorithm>
2 #include <iostream> 
3 #include <limits> 
4
5 using namespace std; 
7 const int MAXN =105; 
8 const int MAXK =105; 
10 int h[MAXN] [MAXK];
11
12 int f(int n,int m)
13 {
14  if (m==1) return n; 
15  if(n==0) return 0; 
16
17 	int ret = numeric_limits<int>::max(); 
18 	for (int i=1;i<=n;i++) 
19    	ret=min(ret,max(f(n-i,m),f(i-1,m-1))+1); 
20 	return ret; 
21 }
22
23 int g(int n,int m)24 {
25 	for (int i=1;i<=n;i++) 
26 		h[i][1] = i; 
27 	for (int j=1;j<=m;j++) 
28 		h[0][j] =0;
29
30 	for (int i=1;i<=n;i++){ 
31 		for(int j=2;j<=m;j++){ 
32 			h[i][j] =numeric_limits<int>::max(); 
33 			for (int k=1;k<=i;k++) 
34 			h[i][j] = min( 
35 				h[i][j], 
36               max(h[i-k][j],h[k-1][j-1])+1); 
37  	} 
38  } 
39
40 	return h[n][m]; 
41 }
42
43 int main()
44 {
45 		int n,m; 
46 		cin>>n>>m; 
47 		cout<<f(n,m)<<endl<<g(n,m)<<endl; 
48 		return 0; 
49 }
  • 判断题
    22. 当输入为 7,3 时,第 19 行采用来去最小值的 min 函数执行了 449 次 ( )
    23. 输出的两行整数总是相同的 ( )
    24. 当m1时,输出的第一行总为n ( )
  • 选择题
    25. 算法·g(n,m)·最为准确的时间复杂度分析结果为( )
    A.O(n·/m) B.O(nm) C.0(n²m) D.0(nm²)
    26. 若输入数据为“202”,输出的第一行为( )。
    A. 4 B.5 C.6 D.20
    27. (4分)当输入为“100 100”时,输出的第一行为( ) 。
    A. 6 B.7 C.8 D.9

3.

1 #include <iostream>2
3 using namespace std;
4
5 intn,k;
6
7 int solvel() 
8 {
9 	int 1=0,r=n; 
10 	while(1<=r) { 
11 		int mid =(1+r)/2; 
12 		if(mid * mid<=n)1=mid+1; 
13 		else r=mid-1; 
14 } 
15 		return 1-1; 
16 }
17
18 double solve2(double x)
19 {
20 		if(x==0) return x; 
21 		for (int i=0;i<k;i++) 
22 			x=(x+n/x)/2;
23 		return x; 
24 }
25
26 int main()
27 {
28 	cin>>n>>k; 
29 	double ans=solve2(solvel()); 
30 	cout<< ans << ’’<< (ans*ans == n) << endl; 
31 	return 0; 
32 }
  • 判断题
    28. 该算法最准确的时间复杂度分析结果为0(logn+k) ()

    1. 当输入为“9801 1”时,输出的第一个数为“99” ( )

    2. 对于任意输入的 n,随着所输入k的增大,输出的第二个数会变成“1” ()

    3. 该程序有存在缺陷。当输入的 n过大时,第 12 行的乘法有可能溢出,因此应当将mid强制转换为 64 位整数再计算 ( )

  • 选择题
    32. 若输入数据为“2 1”则程序输出的第一个数为( )。
    A.1 B.1.414 C.1.5 D.2
    33. 若输入数据为“3 10”则程序输出的第一个数为( )。
    A. 1.7 B.1.732 C.1.75 D.2
    34. 当输入为“256 11”时,输出的第一个数( )。
    A.等于 16 B.接近但小于 16 C.接近但大于 16 D.前3种都有可能

三.完善程序(单选题,每题3分,共计30分)

1.(枚举因数)从小到大打印正整数n的所有因数试补全程序

1 #include <bits/stdc++.h>2 using namespace std;3
4 int main() {
5	int n;	
斯
6	cin >> n;	
7
8	vector<int> fac;	
9	fac.reserve((int )ceil(sqrt(n)));	
10
11	int i;	
12	for(int i=l;i*i<n;i++){	
13	if(①) {	
14	  fac.push_back(i);	
15    }
16	}	
17
18	for(int k=0;k<fac.size();k++) {	
19		cout << ②	<<end1;	
20	}
21 if(③) { 
22 cout<< ④ <<endl; 
23 }
24 for (int k=fac.size()-1;k>=0;--k){ 
25 cout<<⑤<<endl; 
26	}
27 }

35.①处应填( )
A.n%i==0 B.n%i==1
C.n%(i-1)==0 D.n%(i-1)==1

36.②处应填()
A.n/fac[k] B.fac[k]
C.fac[k]-1 D.n/(fac[k]-1)

37.③处应填( )
A.(i-1)*(i-1)==n B.(i-1)*i==n
C.i*i==n D.i*(i-1)==n

38.④处应填( )
A.n-i B.n-i+1
C.i-1 D.i

39.⑤处应填()
A.n/fac[k] B.fac[k]
C.fac[k]-1 D.n/(fac[k]-1)

2. 洪水填充)现有用字符标记像素颜色的 8x8 图像,颜色填充的操作描述如下:给定起点像素的位置和待填充的颜色,将起始像素和所有可达的像素(可达的定义:经过一次或多次的向上、下、左、右四个方向移动所能到达且终点和路径上所有像素的颜色都与起始像素颜色相同),替换为指定的颜色。试补全程序

1 #include<bits/stdc++.h>
2 using namespace std;
3
4 const int ROWS=8;
5 const int COLS=8:
6
7 struct Point{
8 	int r,c; 
9 	Point(int r,int c):r(r),c(c) {} 
10 };
11
12 bool is valid(char image[ROWS][COLS],Point pt,
13 				int prev_color, int new_color) { 
14 		int r=pt.r; 
15 		int c =pt.c; 
16 		return (0<=r && r<ROWS && 0<=c && c<COLS && 
17 				① && image[r][c]!= new_color); 
18 }
19
20 void flood fill(char image[ROWS][COLS], Point cur, int new_color) {
21 		queue<Point> queue; 
22 		queue.push(cur); 
23
24 		int prev_color = image[cur.r][cur.c]; 
25		②;
26
27 		while(!queue.empty()) { 
28 			Point pt = queue.front ();
29 			queue.pop (); 
30
31 			Point points[4] = {③,Point(pt.r-1,pt.c), 
32 			Point(pt.r,pt.c+1),Point(pt.r,pt.c-1)}; 
33 			for(auto p ;points) { 
34			if (is_valid(image,p,prev_color,new_color)){ 
35 				④; 
36 				⑤; 
37 			} 
38		}
39 	}
40 }
41
42 int main() {
43 		char image[ROWS][COLS] = {{’g’,’g','g','g','g','g','g','g'},
44								{'g','g','g','g','g','g','r','r'}, 
45 								{'g','r','r','g','g','r','g','g'}, 
46 								{'g','b','b','b','b','r','g','r'},
47 								{'g','g','g','b','b','r','g','r'}, 
48 								{'g','g','g',’ b','b', 'b','b','r'}, 
49 								{'g','g','g','g','g','b','g','g'}, 
50 								{'g','g','g','g','g','b','b','g'}}; 
51
52 		Point cur(4,4); 
53 		char new_color ='y'; 
54
55 		flood_fill(image, cur, new_color); 
56
57 		for(int r=-;r<ROWS;r++){ 
58 			for (int c=0;c<COLS;c++){ 
59				 cout<<image[r][c]<<’’; 
60		}
61 		cout<<endl; 
62 }
63 //输出: 
64 // g g g g g g g g 
65 // g g g g g g r r 
66 // g r r g g r g g 
67 // g y y y y r g r 
68 // g g g y y r g r 
69 // g g g y y y y r 
70 // g g g g g y g g 
71 // g g g g g y y g
72
73 return 0;
74 }
  1. ①处应填( )。

A.image[r][c] == prev_color

B.image[r][c] != prev_color

C.image[r][c] ==new color

D.image[r][c]!=new color

41.②处应填( )。

A.image[cur.r+1][cur.c]=new_color

B.image[cur.r][cur.c] =new color

C.image[cur.r][cur.c+1]=new_color

D. image[cur.r][cur.c] = prev color

42.③处应填( )。

A. Point(pt.r,pt.c)

B.Point(pt.r,pt.c+1)

C. Point(pt.r+1,pt.c)

D. Point(pt.r+l.pt.c+1)

43.④处应填 ( )。
A.prev_color=image[p,r][p.c]

B.new_color=image[p.r][p.c]

C.image[p.r][p.c]

D.image[p.r][p.c]=newcolor

44.⑤处应填( )。

A. queue.push(p)

B. queue.push(pt)

C. queue.push(cur)

D.queue. push (Point(ROWS,COLS))

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
资源来源于网络,如有侵权,私信立删。 CSP-J/S第一轮时间 CSP-J/S第一轮分为:CSP-J1和CSP-S1。和NOIP第一轮时间一样,CSP-J/S第一轮认证在10月份第三个星期六进行。 CSP-J/S第一轮考察重点 第一轮认证为笔试或机试,主要测试选手有关计算机方面的基本知识,第一轮为资格测试。从2020开始,全部为机试。 CSP-J/S第一轮报名方式 参加CSP-S/J两组两轮认证均须在网上注册报名,注册网站为http://rg.noi.cn。参加认证者必须如实填写个人信息报名,包括但不限于姓名、身份证号、出生日期、性别、就学(学籍学校)/就职单位等,信息一旦注册,不得修改,如有错误,责任自负。 CSP-J/S第一轮认证考点 省认证点由CCF授权的CSP非专业级别省认证组织单位设置。 1、第一轮认证点:由省认证组织单位总负责人设置,每个认证点人数不应少于20人。 2、未经批准的认证点,其认证成绩不予承认。 认证费用 第一轮CSP-S/J组:50元/人(该费用不包括食宿及交通费)。 CSP-J/S第一轮认证试题组成 CSP-J/S第一轮在10月份第三个星期六进行,其中CSP-J1认证时间为周六9:30-11:30,CSP-S1认证时间为周六14:30-16:30。考试时长为2小时,内容为笔试或机试(从2020开始全部为机试),满分100分。 试题由三部分组成: ① 选择题(共15题,每题2分,共计30分) CSP-S1的前10道题为单选题,后10道题为不定项选择题(只有全部选对才得分,否则不得分);CSP-J1的前15道题都是单选题。 ② 程序阅读理解题(共3题,共计40分) 题目给出一段程序(不一定有关于程序功能的说明),考生通过阅读理解该段程序进行答题,分为选择题和判断题。 ③ 程序完善题(共3题,共计30分) 题目给出一段关于程序功能的文字说明,然后给出一段程序代码,在代码中略去了若干个语句或语句的一部分并在这些位置给出空格,要求考生根据程序的功能说明和代码的上下文,选择对应答案 。三题皆为选择题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一枚大果壳

码文不易,晚上熬夜需要点咖啡钱

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值