当前位置:   article > 正文

蓝桥杯2023/3/2_蓝桥杯2023年3月真题 相邻身高差

蓝桥杯2023年3月真题 相邻身高差

1.

小蓝正在学习一门神奇的语言,这门语言中的单词都是由小写英文字母组 成,有些单词很长,远远超过正常英文单词的长度。小蓝学了很长时间也记不住一些单词,他准备不再完全记忆这些单词,而是根据单词中哪个字母出现得最多来分辨单词。

现在,请你帮助小蓝,给了一个单词后,帮助他找到出现最多的字母和这 个字母出现的次数。

  1. word=input()
  2. count=0
  3. arr=[]
  4. for i in word:
  5. counts=word.count(i)
  6. if counts>count:
  7. count=counts
  8. for j in word:
  9. if word.count(j)==count:
  10. arr.append(j)
  11. arr.sort()
  12. print(arr[0])
  13. print(count)

2.成绩统计

补充知识点:round()

round()是python自带的一个函数,用于数字的四舍五入。

  1. num=int(input())
  2. pass_num=0
  3. good_num=0
  4. for i in range(num):
  5. score=int(input())
  6. if score>60:
  7. pass_num=pass_num+1
  8. if score>85:
  9. good_num=good_num+1
  10. pass1=round((pass_num/num)*100)
  11. good1=round((good_num/num)*100)
  12. print("{}%".format(pass1))
  13. print("{}%".format(good1))

3.

补充知识点  abs(x)

abs(x) 是 Python 的一个内置函数,它的功能是返回一个数的绝对值,常用在数学计算中。绝对值是指一个数在数轴上所对应点到原点的距离,是一个非负数。

补充知识点:  math.gcd() 方法

math.gcd()方法是数学模块的一种库方法,用于查找给定数字的GCD(最大公约数),它接受两个整数并返回其最大公约数(将两个数字相除的最大正整数)。

lcm(最小公倍数)

求解lcm时通常用gcd进行辅助计算。
定理:两个自然数的最大公约数与它们的最小公倍数的乘积等于这两个数的乘积。

  1. def Dijkstra(network,s,d): #迪杰克斯拉算法算s-d的最短路径,并返回路径和代价
  2. print("Start Dijkstra Path...")
  3. path=[] #s-d的最短路径
  4. n=len(network) #邻接矩阵维度,即节点个数
  5. fmax=999
  6. w=[[0 for i in range(n)]for j in range(n)] #邻接矩阵转化为维度矩阵,即0->max
  7. book=[0 for i in range(n)] #是否已经是最小的标记列表
  8. dis=[fmax for i in range(n)] #s 到其他节点的最小距离
  9. book[s-1]=1 #节点编号从1开始,列表序号从0开始
  10. midpath=[-1 for i in range(n)] #上一跳列表
  11. for i in range(n):
  12. for j in range(n):
  13. if network[i][j]!=0:
  14. w[i][j]=network[i][j] #0->max
  15. else:
  16. w[i][j]=fmax
  17. if i==s-1 and network[i][j]!=0: #直连的节点最小距离就是network[i][j]
  18. dis[j]=network[i][j]
  19. for i in range(n-1): #n-1次遍历,除了s节点
  20. min=fmax
  21. for j in range(n):
  22. if book[j]==0 and dis[j]<min: #如果未遍历且距离最小
  23. min=dis[j]
  24. u=j
  25. book[u]=1
  26. for v in range(n): #u直连的节点遍历一遍
  27. if dis[v]>dis[u]+w[u][v]:
  28. dis[v]=dis[u]+w[u][v]
  29. midpath[v]=u+1 #上一跳更新
  30. j=d-1 #j是序号
  31. path.append(d) #因为存储的是上一跳,所以先加入目的节点d,最后倒置
  32. while(midpath[j]!=-1):
  33. path.append(midpath[j])
  34. j=midpath[j]-1
  35. path.append(s)
  36. path.reverse() #倒置列表
  37. print(path)
  38. #print(midpath)
  39. print(dis)
  40. #return path
  41. network=[[0,2,1,1,1,0,0,0,0,0,0,0,0,0,0,0,0,0,0],
  42. [2,0,0,0,0,0,0,0,0,2,0,0,0,0,0,0,0,0,0],
  43. [1,0,0,3,0,3,3,0,0,0,0,0,0,0,0,0,0,0,0],
  44. [1,0,3,0,1,0,2,1,2,0,0,0,0,0,0,0,0,0,0],
  45. [1,0,0,1,0,0,0,1,3,0,0,0,0,0,0,0,0,0,0],
  46. [0,0,3,0,0,0,1,0,0,1,0,0,0,0,0,0,0,0,0],
  47. [0,1,3,2,0,1,0,0,0,0,2,3,0,1,0,0,0,0,0],
  48. [0,0,0,1,1,0,0,0,1,0,0,2,0,0,0,0,0,0,0],
  49. [0,0,0,0,3,0,3,1,0,0,0,0,3,0,0,0,0,0,0],
  50. [0,2,0,0,0,1,0,0,0,0,0,0,0,0,0,0,0,0,2],
  51. [0,0,0,0,0,0,2,0,0,0,0,3,0,1,0,0,0,0,0],
  52. [0,0,0,0,0,0,0,2,0,0,3,0,1,0,0,0,0,0,0],
  53. [0,0,0,0,0,0,0,0,3,0,0,1,0,2,0,0,1,0,1],
  54. [0,0,0,0,0,0,0,0,0,0,1,0,2,0,0,1,0,0,0],
  55. [0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,1,1,3,0],
  56. [0,0,0,0,0,0,0,0,0,0,2,0,0,1,1,0,0,0,0],
  57. [0,0,0,0,0,0,0,0,0,0,0,0,1,0,1,0,0,0,0],
  58. [0,0,0,0,0,0,0,0,0,0,0,0,0,0,3,0,0,0,1],
  59. [0,0,0,0,0,0,0,0,0,0,2,0,0,1,0,0,0,0,1]
  60. ]
  61. Dijkstra(network,1,19)
  1. #弗洛一德算法
  2. # 请在此输入您的代码
  3. M = 999
  4. matrix = [
  5. [0, 2, 1, 1, 1, M, M, M, M, M, M, M, M, M, M, M, M, M, M],
  6. [2, 0, M, M, M, M, 1, M, M, 2, M, M, M, M, M, M, M, M, M],
  7. [1, M, 0, 3, M, 3, 3, M, M, M, M, M, M, M, M, M, M, M, M],
  8. [1, M, 3, 0, 1, M, 2, 1, 2, M, M, M, M, M, M, M, M, M, M],
  9. [1, M, M, 1, 0, M, M, 1, 3, M, M, M, M, M, M, M, M, M, M],
  10. [M, M, 3, M, M, 0, 1, M, M, M, M, M, M, M, M, M, M, M, M],
  11. [M, 1, 3, 2, M, 1, 0, M, 3, M, M, M, M, M, M, M, M, M, M],
  12. [M, M, M, 1, 1, M, M, 0, 1, M, M, 2, M, M, M, M, M, M, M],
  13. [M, M, M, 2, 3, M, 3, 1, 0, M, M, M, M, M, M, M, M, M, M],
  14. [M, 2, M, M, M, 1, M, M, M, 0, M, M, M, M, M, M, M, M, 2],
  15. [M, M, M, M, M, M, 2, M, M, M, 0, 3, M, 1, M, 2, M, M, M],
  16. [M, M, M, M, M, M, M, 2, M, M, 3, 0, 1, M, M, M, M, 1, M],
  17. [M, M, M, M, M, M, M, M, 3, M, M, 1, 0, 2, M, M, 1, M, 1],
  18. [M, M, M, M, M, M, M, M, M, M, 1, M, 2, 0, M, 1, M, M, M],
  19. [M, M, M, M, M, M, M, M, M, M, M, M, M, M, 0, 1, 1, 3, M],
  20. [M, M, M, M, M, M, M, M, M, M, 2, M, M, 1, 1, 0, M, M, M],
  21. [M, M, M, M, M, M, M, M, M, M, M, M, 1, M, 1, M, 0, M, M],
  22. [M, M, M, M, M, M, M, M, M, M, M, 1, M, M, 3, M, M, 0, 1],
  23. [M, M, M, M, M, M, M, M, M, 2, M, M, 1, M, M, M, M, 1, 0],
  24. ]
  25. n = len(matrix)
  26. for i in range(n):
  27. for j in range(n):
  28. for k in range(n):
  29. matrix[i][j] = min(matrix[i][j], matrix[i][k] + matrix[k][j])
  30. print(matrix[0][18])

4.

小明刚刚找到工作,老板人很好,只是老板夫人很爱购物。老板忙的时候经常让小明帮忙到商场代为购物。小明很厌烦,但又不好推辞。

这不,大促销又来了!老板夫人开出了长长的购物单,都是有打折优惠的。

小明也有个怪癖,不到万不得已,从不刷卡,直接现金搞定。

现在小明很心烦,请你帮他计算一下,需要从取款机上取多少现金,才能搞定这次购物。

取款机只能提供 100元面额的纸币。小明想尽可能少取些现金,够用就行了。 你的任务是计算出,小明最少需要取多少现金。

以下是让人头疼的购物单,为了保护隐私,物品名称被隐藏了。

python ceil 函数是返回值上限的X - 不小于x的最小整数。
说明:

这个函数返回值上限的X - 不小于x的最小整数。

语法:

import math

math.ceil( x )

注:此功能是不能直接访问的,所以我们需要导入的数学模块,然后我们需要调用这个函数,用数学的静态对象。

  1. import math
  2. arr='''
  3. **** 180.90 88折
  4. **** 10.25 65折
  5. **** 56.14 9折
  6. **** 104.65 9折
  7. **** 100.30 88折
  8. **** 297.15 半价
  9. **** 26.75 65折
  10. **** 130.62 半价
  11. **** 240.28 58折
  12. **** 270.62 8折
  13. **** 115.87 88折
  14. **** 247.34 95折
  15. **** 73.21 9折
  16. **** 101.00 半价
  17. **** 79.54 半价
  18. **** 278.44 7折
  19. **** 199.26 半价
  20. **** 12.97 9折
  21. **** 166.30 78折
  22. **** 125.50 58折
  23. **** 84.98 9折
  24. **** 113.35 68折
  25. **** 166.57 半价
  26. **** 42.56 9折
  27. **** 81.90 95折
  28. **** 131.78 8折
  29. **** 255.89 78折
  30. **** 109.17 9折
  31. **** 146.69 68折
  32. **** 139.33 65折
  33. **** 141.16 78折
  34. **** 154.74 8折
  35. **** 59.42 8折
  36. **** 85.44 68折
  37. **** 293.70 88折
  38. **** 261.79 65折
  39. **** 11.30 88折
  40. **** 268.27 58折
  41. **** 128.29 88折
  42. **** 251.03 8折
  43. **** 208.39 75折
  44. **** 128.88 75折
  45. **** 62.06 9折
  46. **** 225.87 75折
  47. **** 12.89 75折
  48. **** 34.28 75折
  49. **** 62.16 58折
  50. **** 129.12 半价
  51. **** 218.37 半价
  52. **** 289.69 8折
  53. '''
  54. arr=arr.split()
  55. sum=0
  56. for i in range(0,len(arr),3):
  57. data=float(arr[i+1])
  58. discount=arr[i+2]
  59. if len(discount)==2:
  60. if discount=='半价':
  61. discount=0.5
  62. else :
  63. discount=float(discount[:-1])*0.1
  64. else:
  65. discount=float(discount[:-1])*0.01
  66. sum=sum+data*discount
  67. print(math.ceil(sum/100)*100)

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/不正经/article/detail/451407
推荐阅读
相关标签
  

闽ICP备14008679号