鱼C论坛

 找回密码
 立即注册
查看: 1854|回复: 14

[已解决]技术部门大佬出了python题目,我感觉头晕晕得,各位大佬看看。

[复制链接]
发表于 2020-8-24 11:22:40 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
Python 笔试题


1. 代码a=[1,2,3,4,5],以下输出结果正确的是?()
A  print(a[:]) => [1,2,3,4,5]
B  print(a[0:]) => [2,3,4,5]
C  print(a[:100]) => [1,2,3,4,5]
D  print(a[-1:]) => [1,2]

2.正则匹配,匹配日期2018-03-20
url=’https://sycm.taobao.com/bda/trad ... amp;_=1521595613462



3.l = [2,1,2,3,4,5,6,6,5,4,3,2,1],将列表去重后进行输出,并保持原有顺序不变。



4.一串字母数字组合的字符串,找出相同的字母或数字,并按照个数排序。
l = [1,2,3,'a','b','c',1,2,'a','b',3,'c','d','a','b',1]


5.l=[1,2,3,4,5,6,7,8] 数据不重复,target=6,快速找出数组中两个元素之和等于target 的数组下标。



6.求n的阶乘



7.写函数实现斐波那切数列是 1 1 2 3 5 8 ...这样的序列。前两个数为1,后面的数为前两个数之和。



8.写出冒泡排序函数



9.判断括号是否闭合text = "({[({{abc}})][{1}]})2([]){({[]})}[]"



10.合并两个有序序列,并保持有序
最佳答案
2020-8-25 00:12:17
seslovelm 发表于 2020-8-24 23:22
7.8.9.10 这几题该怎么做呢?

他那个做的都不对,前面两题错了,其他的也有问题
看看这个:
  1. #1. 代码],以下输出结果正确的是?()
  2. #A  print(a[:]) => [1,2,3,4,5]
  3. #B  print(a[0:]) => [2,3,4,5]
  4. #C  print(a[:100]) => [1,2,3,4,5]
  5. #D  print(a[-1:]) => [1,2]
  6. #明显答案是A,C
  7. a=[1,2,3,4,5]
  8. print(a[:])
  9. print(a[:100])

  10. #2.正则匹配,匹配日期2018-03-20
  11. import re
  12. url='https://sycm.taobao.com/bda/tradinganaly/overview/get_summary.json?dateRange=2018-03-20%7C2018-03-20&dateType=recent1&device=1&token=ff25b109b&_=1521595613462'
  13. rule=r'\d{4}-\d{2}-\d{2}'
  14. result=re.findall(rule,url)
  15. print(result)

  16. # 3.l = [2,1,2,3,4,5,6,6,5,4,3,2,1],将列表去重后进行输出,并保持原有顺序不变。
  17. l = [2, 1, 2, 3, 4, 5, 6, 6, 5, 4, 3, 2, 1]
  18. n = []
  19. for i in l:
  20.     if i not in n:
  21.         n.append(i)
  22. print(n)

  23. # 4.一串字母数字组合的字符串,找出相同的字母或数字,并按照个数排序。
  24. l = [1, 2, 3, 'a', 'b', 'c', 1, 2, 'a', 'b', 3, 'c', 'd', 'a', 'b', 1]
  25. n = [(i, l.count(i)) for i in set(l)]
  26. n.sort(key=lambda x: x[1], reverse=True)
  27. k = [n[p][0] for p in range(len(n)) for q in range(n[p][1])]
  28. print(k)

  29. # 5.l=[1,2,3,4,5,6,7,8] 数据不重复,target=6,快速找出数组中两个元素之和等于target 的数组下标。
  30. target = 6
  31. l = [1, 2, 3, 4, 5, 6, 7, 8]
  32. for i in range(len(l)):
  33.     a = target - l[i]
  34.     if (a in l) and a != l[i]:
  35.         print(f'元素为{l[i], a}')
  36.         print(f'元素下标为{i, l.index(a)}')

  37. # 6.求n的阶乘,这个网上找的,阶乘是什么不知道
  38. def factorial(n):
  39.     result = n
  40.     for i in range(1,n):
  41.         result *= i
  42.     return result
  43. print(factorial(4))

  44. # 7.写函数实现斐波那切数列是 1 1 2 3 5 8 ...这样的序列。前两个数为1,后面的数为前两个数之和。
  45. a=[1,1]
  46. for i in range(2,20):
  47.     a.append(a[i-2]+a[i-1])
  48. print(a)

  49. #8.写出冒泡排序函数
  50. a=[1,2,3,4,5,6,7,8]
  51. for i in range(0,len(a)):
  52.     for j in range(0,len(a)):
  53.         if a[i] > a[j]:
  54.             a[i],a[j]=a[j],a[i]
  55. print(a)

  56. #9.判断括号是否闭合text = "({[({{abc}})][{1}]})2([]){({[]})}[]"
  57. #这个从内层开始,数仔细点就知道了吧

  58. #10.合并两个有序序列,并保持有序,指列表和元组?
  59. a=[1,2,3]
  60. b=[6,7,8]
  61. c=[]
  62. c.extend(a)
  63. c.extend(b)
  64. print(c)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-8-24 16:14:35 | 显示全部楼层
2
  1. re.search(r'dateRange=(.*)\|', url).group(1)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-8-24 16:22:03 | 显示全部楼层
3
  1. l = [2,1,2,3,4,5,6,6,5,4,3,2,1]
  2. s = set()
  3. for e in l:
  4.     if e not in s:
  5.         s.add(e)
  6.         print(e)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-8-24 16:34:56 | 显示全部楼层
你这个是要求闭卷考试?还是开卷可以电脑尝试的?
第一题是选A,C么,本来以为C不对,试了下发现居然行的。。。。。。。。。。。
第二题这样可以么?
  1. import re
  2. url='https://sycm.taobao.com/bda/tradinganaly/overview/get_summary.json?dateRange=2018-03-20%7C2018-03-20&dateType=recent1&device=1&token=ff25b109b&_=1521595613462'
  3. rule=r'\d{4}-\d{2}-\d{2}'
  4. result=re.findall(rule,url)
  5. print(result)

复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-8-24 16:37:28 | 显示全部楼层
4
  1. l = [1,2,3,'a','b','c',1,2,'a','b',3,'c','d','a','b',1]
  2. r = sorted(l, key = lambda x:l.count(x))
  3. print(r)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-8-24 16:53:00 | 显示全部楼层
  1. ['d', 2, 3, 'c', 2, 3, 'c', 1, 'a', 'b', 1, 'a', 'b', 'a', 'b', 1]
复制代码

这个不对啊,结果是这样的
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2020-8-24 17:02:51 | 显示全部楼层
1.AB
2.url有问题
3.
  1. l = [2,1,2,3,4,5,6,6,5,4,3,2,1]
  2. delete = []
  3. num = len(l)
  4. for i in range(1,num):
  5.     for e in range(i):
  6.         if l[i] == l[e]:
  7.             delete.append(i)
  8.             break
  9. delete.sort(reverse=True)
  10. for i in delete:
  11.     l.pop(i)
  12. print(l)
复制代码

4.
  1. l = [1,2,3,'a','b','c',1,2,'a','b',3,'c','d','a','b',1]
  2. set_1 = set(l)
  3. result = [(item, l.count(item)) for item in set_1]
  4. result.sort(key=lambda x:x[1], reverse=True)
  5. print(result)
复制代码

5.
  1. l = [1,2,3,4,5,6,7,8]
  2. set1 = set(list1)
  3. target = 6

  4. result = []
  5. for a in list1:
  6.     b = target - a
  7.     if a < b < target and b in set1:
  8.         result.append((list1.index(a), list1.index(b)))
  9. print(result)
复制代码

6.
  1. n = int(input())
  2. a = 1
  3. for i in range(1,n+1):
  4.     a = a*i
  5. print(a)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-8-24 17:04:44 | 显示全部楼层
本帖最后由 挥舞乾坤 于 2020-8-24 17:42 编辑
疾风怪盗 发表于 2020-8-24 16:53
这个不对啊,结果是这样的


这题我理解就是这样的,把原列表排序,前面的是出现频率少的,可能我理解错了,或者是得到一个新的去重的列表,按出现频率排序,或者这样
  1. l = [1,2,3,'a','b','c',1,2,'a','b',3,'c','d','a','b',1]
  2. r = {}
  3. for e in l:
  4.     r.setdefault(e,0)
  5.     r[e] += 1
  6. r = sorted(r.items(), key=lambda x:x[1])
  7. print(r)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-8-24 17:41:00 | 显示全部楼层

可能是对题理解有问题,或者这样:
  1. l = [1,2,3,'a','b','c',1,2,'a','b',3,'c','d','a','b',1]
  2. r = {}
  3. for e in l:
  4.     r.setdefault(e,0)
  5.     r[e] += 1
  6. r = sorted(r.items(), key=lambda x:x[1])
  7. print(r)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-8-24 23:15:26 | 显示全部楼层

7,8,9,10 题目该怎么做呢?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2020-8-24 23:22:25 | 显示全部楼层
挥舞乾坤 发表于 2020-8-24 17:41
可能是对题理解有问题,或者这样:

7.8.9.10 这几题该怎么做呢?
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-8-25 00:12:17 | 显示全部楼层    本楼为最佳答案   
seslovelm 发表于 2020-8-24 23:22
7.8.9.10 这几题该怎么做呢?

他那个做的都不对,前面两题错了,其他的也有问题
看看这个:
  1. #1. 代码],以下输出结果正确的是?()
  2. #A  print(a[:]) => [1,2,3,4,5]
  3. #B  print(a[0:]) => [2,3,4,5]
  4. #C  print(a[:100]) => [1,2,3,4,5]
  5. #D  print(a[-1:]) => [1,2]
  6. #明显答案是A,C
  7. a=[1,2,3,4,5]
  8. print(a[:])
  9. print(a[:100])

  10. #2.正则匹配,匹配日期2018-03-20
  11. import re
  12. url='https://sycm.taobao.com/bda/tradinganaly/overview/get_summary.json?dateRange=2018-03-20%7C2018-03-20&dateType=recent1&device=1&token=ff25b109b&_=1521595613462'
  13. rule=r'\d{4}-\d{2}-\d{2}'
  14. result=re.findall(rule,url)
  15. print(result)

  16. # 3.l = [2,1,2,3,4,5,6,6,5,4,3,2,1],将列表去重后进行输出,并保持原有顺序不变。
  17. l = [2, 1, 2, 3, 4, 5, 6, 6, 5, 4, 3, 2, 1]
  18. n = []
  19. for i in l:
  20.     if i not in n:
  21.         n.append(i)
  22. print(n)

  23. # 4.一串字母数字组合的字符串,找出相同的字母或数字,并按照个数排序。
  24. l = [1, 2, 3, 'a', 'b', 'c', 1, 2, 'a', 'b', 3, 'c', 'd', 'a', 'b', 1]
  25. n = [(i, l.count(i)) for i in set(l)]
  26. n.sort(key=lambda x: x[1], reverse=True)
  27. k = [n[p][0] for p in range(len(n)) for q in range(n[p][1])]
  28. print(k)

  29. # 5.l=[1,2,3,4,5,6,7,8] 数据不重复,target=6,快速找出数组中两个元素之和等于target 的数组下标。
  30. target = 6
  31. l = [1, 2, 3, 4, 5, 6, 7, 8]
  32. for i in range(len(l)):
  33.     a = target - l[i]
  34.     if (a in l) and a != l[i]:
  35.         print(f'元素为{l[i], a}')
  36.         print(f'元素下标为{i, l.index(a)}')

  37. # 6.求n的阶乘,这个网上找的,阶乘是什么不知道
  38. def factorial(n):
  39.     result = n
  40.     for i in range(1,n):
  41.         result *= i
  42.     return result
  43. print(factorial(4))

  44. # 7.写函数实现斐波那切数列是 1 1 2 3 5 8 ...这样的序列。前两个数为1,后面的数为前两个数之和。
  45. a=[1,1]
  46. for i in range(2,20):
  47.     a.append(a[i-2]+a[i-1])
  48. print(a)

  49. #8.写出冒泡排序函数
  50. a=[1,2,3,4,5,6,7,8]
  51. for i in range(0,len(a)):
  52.     for j in range(0,len(a)):
  53.         if a[i] > a[j]:
  54.             a[i],a[j]=a[j],a[i]
  55. print(a)

  56. #9.判断括号是否闭合text = "({[({{abc}})][{1}]})2([]){({[]})}[]"
  57. #这个从内层开始,数仔细点就知道了吧

  58. #10.合并两个有序序列,并保持有序,指列表和元组?
  59. a=[1,2,3]
  60. b=[6,7,8]
  61. c=[]
  62. c.extend(a)
  63. c.extend(b)
  64. print(c)
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-8-25 00:37:52 | 显示全部楼层
本帖最后由 Stubborn 于 2020-8-25 01:04 编辑
  1. 1,AC

  2. 2,pattern = "\d{4}-\d{1,3}-\d{1,2}"

  3. 3,list(set(l))

  4. 4, for i in set(l):
  5.         dict[i] = l.count(i)

  6. 5
  7. #    二分法 left right mid
  8. #       当nums[mid] > target  -->   则需要的结果在nums[left: mid]
  9. #       当nums[mid] < target  -->   则需要的结果在nums[mid+1: right]
  10. #       left > right 返回结果left

  11. left = 0
  12. right = len(nums)

  13. while left < right:

  14.     mid = (left + right) // 2

  15.     if nums[mid] > target:
  16.         right = mid
  17.     elif nums[mid] < target:
  18.         left = mid + 1
  19.     else:
  20.         return mid
  21. return left

  22. 6.
  23. def func(i):
  24.     if i == 1: return i
  25.     return i * func(i-1)

  26. 7.
  27. def func():
  28.     a = 1
  29.     yield a
  30.     b = 1
  31.     yield b

  32.     while True:
  33.         a,b = b, a + b
  34.         if b > 100: raise StopIteration
  35.         yield b

  36. 8.
  37. def Sorting_bubbling(array: List[int]) -> list:
  38.     length = len(array)
  39.     for r in range(length):
  40.         for l in range(r + 1, length):
  41.             if array[r] > array[l]: array[r], array[l] = array[l], array[r]
  42.     return array

  43. 9.题意不明。怎么样算闭合,完整的[]{}()  里面有数字或者字母
  44. 10.题意不明。怎么样的有序?给例子
  45. """
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-8-25 10:26:12 | 显示全部楼层
疾风怪盗 发表于 2020-8-25 00:12
他那个做的都不对,前面两题错了,其他的也有问题
看看这个:

题5的快速找出感觉有些像leecode上的两数之和,当列表很长的时候不能直接遍历,用字典应该是一个思路。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-8-25 10:32:55 | 显示全部楼层
求资专用 发表于 2020-8-25 10:26
题5的快速找出感觉有些像leecode上的两数之和,当列表很长的时候不能直接遍历,用字典应该是一个思路。

用字典?如何找?不太懂,我满打满就学了3个月,只会用最基础的
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-26 03:31

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表