欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 汽车 > 维修 > 2024年06月CCF-GESP编程能力等级认证Python编程四级真题解析

2024年06月CCF-GESP编程能力等级认证Python编程四级真题解析

2024/11/30 12:32:56 来源:https://blog.csdn.net/gozhuyinglong/article/details/140293104  浏览:    关键词:2024年06月CCF-GESP编程能力等级认证Python编程四级真题解析

本文收录于专栏《Python等级认证CCF-GESP真题解析》,专栏总目录:点这里,订阅后可阅读专栏内所有文章。

一、单选题(每题 2 分,共 30 分)

第 1 题

小杨父母带他到某培训机构给他报名参加CCF组织的GESP认证考试的第1级,那他可以选择的认证语言有几种?( )
A. 1
B. 2
C. 3
D. 4

答案:C

第 2 题

下面流程图在yr输入2024时,可以判定yr代表闰年,并输出 2月是29天 ,则图中菱形框中应该填入( )。
在这里插入图片描述

A. (yr%400==0) || (yr%4==0)
B. (yr%400==0) || (yr%4==0 && yr%100!=0)
C. (yr%400==0) && (yr%4==0)
D. (yr%400==0) && (yr%4==0 && yr%100!=0)

答案:B

第 3 题

执行下面Python代码后,输出的结果可能是?( )

name = ('Tom', 'Join', 'Gaia')
age = (10, 13, 12)
print({(a.upper(), b) for a, b in zip(name, age)})

A. {‘Tom’: 10, ‘Join’: 13, ‘Gaia’: 12}
B. {‘TOM’: 10, ‘JOIN’: 13, ‘GAIA’: 12}
C. {(‘JOIN’, 13), (‘TOM’, 10), (‘GAIA’, 12)}
D. {(‘Join’, 13), (‘Tom’, 10), (‘Gaia’, 12)}

答案:C

第 4 题

函数fun的定义如下,调用该函数的语句错误的是?( )

def fun(x, y, z=3):print(x, y, z)

A. fun(1, 2, 3)
B. fun(1, 2)
C. fun(y=2, x=1)
D. fun(1, y=2, 3)

答案:D

第 5 题

执行下面Python代码后,输出的结果是?( )

def fun(x, y, *nums):res = x + yfor i in nums:res += ireturn resprint(fun(10, 20, 15, 25, 30))

A. 30
B. 45
C. 100
D. 语法错误

答案:C

第 6 题

执行下面Python代码后,输出的结果是?( )

def fun(x, y, **kwargs):res = x + yfor i in kwargs.values():res += ireturn resprint(fun(10, 20, A=6, B=1, C=3))

A. 40
B. 36
C. 30
D. 语法错误

答案:A

第 7 题

执行下面python代码后,输出的结果是?( )

def add():count = 1def fun():nonlocal countprint(count, end="#")count += 2return funa = add()
a()
a()

A. 1#3#
B. 1#1#
C. 3#3#
D. add函数语法错误

答案:A

第 8 题

执行下面python代码后,输出的结果是?( )

s = 1def sums(n):global ss = 0s = s + nprint(s, end="#")sums(5)
print(s, end="#")

A. 5#5#
B. 5#1#
C. 1#1#
D. 1#5#

答案:A

第 9 题

执行下面python代码后,输出的结果是?( )

def add(c):d = c.append(40)return da = [10, 20, 30]
b = add(a)
print(a, b)

A. [10, 20, 30] [10, 20, 30]
B. [10, 20, 30, 40] [10, 20, 30, 40]
C. [10, 20, 30] [10, 20, 30, 40]
D. [10, 20, 30, 40] None

答案:D

第 10 题

在一个农场上,有一头母牛。根据农场的规则,这头母牛每年年初都会生出一头小母牛。每头新生的小母牛从它们出生的第四个年头开始,也会每年年初生出一头新的小母牛。假设没有母牛死亡,并且每头母牛都严格遵循这个规则。下列程序用来计算在第 年时,农场上共有多少头母牛,其中横线处填写的代码为?()

lst = [0] * 100
lst[1:4] = [1, 2, 3, 4]def calculate_cows(n):if n <= 4:return lst[n]i = 5while i <= n:lst[i] = __________i += 1return lst[i - 1]

A. lst[i - 1] + lst[i - 3]
B. lst[i - 2] + lst[i - 3]
C. lst[i - 1] + lst[i - 2]
D. lst[-1] + lst[-3]

答案:A

第 11 题

程序段如下:

def fun(arr: list):n = len(arr)for i in range(n - 1):for j in range(0, n - i - 1):if arr[j] > arr[j + 1]:arr[j], arr[j + 1] = arr[j + 1], arr[j]

其中,n为正整数,则该段程序的最坏时间复杂度是?( )
A. O ( n ) O(n) O(n)
B. O ( 2 n ) O(2n) O(2n)
C. O ( n 3 ) O(n^3) O(n3)
D. O ( n 2 ) O(n^2) O(n2)

答案:D

第 12 题

执行下面Python代码后,输出的结果是?( )

users = [{"name": "Tom", "skills": {"Python", "Java", "C++"}},{"name": "Join", "skills": {"Python", "Java"}},{"name": "Gaia", "skills": {"Java", "C++", "SQL"}}
]skills_sets = (user['skills'] for user in users)
common_skills = set.intersection(*skills_sets)
print(common_skills)

A. {‘Java’, Python’}
B. {SQL’, ‘C++’}
C. {‘Java’, ‘SQL’, ‘Python’, ‘C++’}
D. {‘Java’}

答案:D

第 13 题

执行下面Python代码后,输出的结果是?( )

lst = [1, 4, 3, 5, 2]
lst = [i[0] for i in sorted(enumerate(lst), key=lambda x: x[1])]
print(lst)

A. [3, 1, 2, 4, 0]
B. [0, 4, 2, 1, 3]
C. [3, 0, 2, 1, 4]
D. [0, 3, 2, 4, 1]

答案:B

第 14 题

执行下面Python代码后,文件ip.txt中的内容用记事本打开时显示为?( )

with open("ip.txt", "w") as f:lst = ["202.206.224.21\n", "192.168.224.1\n"]f.writelines(lst)

A. 202.206.224.21192.168.224.1
B. 202.206.224.21
192.168.224.1
C. 202.206.224.21\n192.168.224.1
D. 202.206.224.21\n192.168.224.1\n

答案:B

第 15 题

执行下面Python代码,输入0和字符串“abc”后,输出的结果是?( )

try:a = int(input())b = int(input())x = a / bprint(x, end="#")
except ZeroDivisionError:print(0, end="#")
except:print(1, end="#")
else:print(2, end="#")
finally:print(3, end="#")

A. 0#2#3#
B. 0#3#
C. 1#2#3#
D. 1#3#

答案:D

二、判断题(每题 2 分,共 20 分)

第 16 题

GESP测试是对认证者的编程能力进行等级认证,同一级别的能力基本上与编程语言无关。( )

答案:正确

第 17 题

在Python中,print(list(“GESP”))执行后输出[‘G’, ‘E’, ‘S’, ‘P’]。( )

答案:正确

第 18 题

执行下面Python代码后,输出两个True。

print("h" in "hello")
print("he" in "hello")

答案:正确

第 19 题

执行下面Python代码后,输出两个True。

lst1 = [1, 2, 3]
lst2 = lst1[:]
print(lst1 == lst2, lst1 is lst2)

答案:错误

第 20 题

执行下面Python代码,调用函数fun可以得到一个元组类型的数据。

def fun(a, b):return a // b, a % bprint(type(fun(8, 5)))

答案:正确

第 21 题

Python程序中,全局变量与局部变量不允许重名。

答案:错误

第 22 题

下面这段程序的时间复杂度为平方阶 O ( n 2 ) O(n^2) O(n2)。( )

def fun(n):sum1 = 0for i in range(n):sum1 += i

答案:错误

第 23 题

Python在处理程序异常时,异常处理结构能够发现程序段中的语法错误。

答案:错误

第 24 题

要打开一个已经存在的图片文件并读取但不修改数据,则打开模式应该设定为rb。

答案:正确

第 25 题

执行下面Python代码后,输出的结果为za。

print(max('az', 'za', key=lambda a: a[0]))

答案:正确

三、编程题(每题 25 分,共 50 分)

第 26 题

试题名称:黑白方块
时间限制:1.0 s
内存限制:512.0 MB
题面描述
小杨有一个 n n n m m m 列的网格图,其中每个格子要么是白色,要么是黑色。
对于网格图中的一个子矩形,小杨认为它是平衡的当且仅当其中黑色格子与白色格子数量相同。
小杨想知道最大的平衡子矩形包含了多少个格子。
输入格式
第一行包含两个正整数 n , m n,m n,m,含义如题面所示。
之后 n n n 行,每行一个长度为 m m m 01 01 01 串,代表网格图第 i i i 行格子的颜色,如果为 0 0 0,则对应格子为白色,否则为黑色。
输出格式
输出一个整数,代表最大的平衡子矩形包含格子的数量,如果不存在则输出 0 0 0
样例1

4 5
00000
01111
00011
00011
16

样例解释
对于样例1,假设 ( i , j i,j i,j ) 代表第 i i i 行第 j j j 列,最大的平衡子矩形的四个顶点分别为 (1,2),(1,5),(4,2),(4,5)。
数据范围
对于全部数据,保证有 1 ≤ n , m ≤ 10 1 ≤ n, m ≤ 10 1n,m10
参考程序

N = 55
w = [[0] * N for _ in range(N)]def check(xa, ya, xb, yb):a = [0, 0]for i in range(xa, xb + 1):for j in range(ya, yb + 1):a[w[i][j]] += 1return a[0] == a[1]def main():n, m = map(int, input().split())for i in range(1, n + 1):s = input()for j in range(1, m + 1):w[i][j] = int(s[j - 1])ans = 0for i in range(1, n + 1):for j in range(1, m + 1):for ii in range(i, n + 1):for jj in range(j, m + 1):if check(i, j, ii, jj):ans = max(ans, (ii - i + 1) * (jj - j + 1))print(ans)if __name__ == "__main__":
main()

第 27 题

试题名称:宝箱
时间限制:1.0 s
内存限制:512.0 MB
题面描述
小杨发现了 n n n 个宝箱,其中第 i i i 个宝箱的价值是 a i a_i ai
小杨可以选择一些宝箱放入背包并带走,但是小杨的背包比较特殊,假设小杨选择的宝箱中最大价值为 x x x,最小价值为 y y y,小杨需要保证 x − y ≤ k x - y ≤ k xyk,否则小杨的背包会损坏。
小杨想知道背包不损坏的情况下,自己能够带走宝箱的总价值最大是多少。
输入格式
第一行包含两个正整数 n , k n,k n,k,含义如题面所示。
第二行包含 n n n 个正整数 a 1 , a 2 , . . . , a n a_1,a_2,...,a_n a1,a2,...,an,代表宝箱的价值。
输出格式
输出一个整数,代表带走宝箱的最大总价值。
样例1

5 1
1 2 3 1 2
7

样例解释
在背包不损坏的情况下,小杨可以拿走两个价值为 2 2 2 的宝箱和一个价值为 3 3 3 的宝箱。
数据范围
对于全部数据,保证有 1 ≤ n ≤ 1000 , 0 ≤ k ≤ 1000 , 1 ≤ a i ≤ 1000 1 ≤ n ≤ 1000, 0 ≤ k ≤ 1000, 1 ≤ a_i ≤ 1000 1n1000,0k1000,1ai1000
参考程序

N = 1010
a = [0] * Ndef main():n, k = map(int, input().split())aa = input().split()for i in range(1, n + 1):a[i] = int(aa[i-1])a[1:n + 1] = sorted(a[1:n + 1])ans = 0for i in range(1, n + 1):sum = 0for j in range(i, 0, -1):if a[i] - a[j] <= k:sum += a[j]else:breakans = max(ans, sum)print(ans)if __name__ == "__main__":main()

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com