关于面试总结4-python笔试题

前言

现在面试测试岗位,一般会要求熟悉一门语言(python/java),为了考验求职者的基本功,一般会出2个笔试题,这些题目一般不难,主要考察基本功。
要是给你一台电脑,在编辑器里面边写边调试,没多大难度。主要是给你一张纸和笔,让你现场写出来,那就没那么容易了。
(本篇代码都是基于python3.6)

1.统计

统计在一个队列中的数字,有多少个正数,多少个负数,如[1, 3, 5, 7, 0, -1, -9, -4, -5, 8]

方法一

  1. # coding:utf-8
  2. a = [1, 3, 5, 7, 0, -1, -9, -4, -5, 8]
  3. # 用列表生成式,生成新的列表
  4. b = [i for i in a if i > 0]
  5. print("大于0的个数:%s" % len(b))
  6. c = [i for i in a if i < 0]
  7. print("小于0的个数:%s" % len(c))

方法二

  1. # coding:utf-8
  2. a = [1, 3, 5, 7, 0, -1, -9, -4, -5, 8]
  3. # 用传统的判断思维,累加
  4. m = 0
  5. n = 0
  6. for i in a:
  7. if i > 0:
  8. m += 1
  9. elif i < 0:
  10. n += 1
  11. else:
  12. pass
  13. print("大于0的个数:%s" % m)
  14. print("小于0的个数:%s" % n)

2.字符串切片

字符串 "axbyczdj",如果得到结果“abcd”

方法一

  1. # 字符串切片
  2. a = "axbyczdj"
  3. print(a[::2])

方法二

  1. # 传统思维
  2. a = "axbyczdj"
  3. c = []
  4. for i in range(len(a)):
  5. if i % 2 == 0:
  6. c.append(a[i])
  7. print("".join(c))

3.字符串切割

已知一个字符串为“hello_world_yoyo”, 如何得到一个队列 ["hello","world","yoyo"]

  1. a = "hello_world_yoyo"
  2. b = a.split("_")
  3. print(b)

4.格式化输出

已知一个数字为1,如何输出“0001”

  1. a = 1
  2. print("%04d" % a)

5.队列

已知一个队列,如: [1, 3, 5, 7], 如何把第一个数字,放到第三个位置,得到:[3, 5, 1, 7]

  1. a = [1, 3, 5, 7]
  2. # insert插入数据
  3. a.insert(3, a[0])
  4. print(a[1:])

6.交换

已知 a = 9, b = 8,如何交换a和b的值,得到a的值为8,b的值为9

方法1

  1. a = 8
  2. b = 9
  3. a, b = b, a
  4. print(a)
  5. print(b)

方法2

  1. a = 8
  2. b = 9
  3. # 用中间变量c
  4. c = a
  5. a = b
  6. b = c
  7. print(a)
  8. print(b)

7.水仙花

打印出100-999所有的"水仙花数",所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数本身。例如:153是一个"水仙花数",因为153=1的三次方+5的三次方+3的三次方。

  1. sxh = []
  2. for i in range(100, 1000):
  3. s = 0
  4. m = list(str(i))
  5. for j in m:
  6. s += int(j)**len(m)
  7. if i == s:
  8. print(i)
  9. sxh.append(i)
  10. print("100-999的水仙花数:%s" % sxh)

8.完全数

如果一个数恰好等于它的因子之和,则称该数为“完全数”,又称完美数或完备数。 例如:第一个完全数是6,它有约数1、2、3、6,除去它本身6外,其余3个数相加,
1+2+3=6。第二个完全数是28,它有约数1、2、4、7、14、28,除去它本身28外,其余5个数相加,1+2+4+7+14=28。
那么问题来了,求1000以内的完全数有哪些?

  1. a = []
  2. for i in range(1, 1000):
  3. s = 0
  4. for j in range(1, i):
  5. if i % j == 0 and j < i:
  6. s += j
  7. if s == i:
  8. print(i)
  9. a.append(i)
  10. print("1000以内完全数:%s" % a)

9.排序

用python写个冒泡排序

  1. a = [1, 3, 10, 9, 21, 35, 4, 6]
  2. s = range(1, len(a))[::-1]
  3. print(list(s)) # 交换次数
  4. for i in s:
  5. for j in range(i):
  6. if a[j] > a[j + 1]:
  7. a[j], a[j + 1] = a[j + 1], a[j]
  8. print("第 %s 轮交换后数据:%s" % (len(s)-i+1, a))
  9. print(a)

10.sort排序

已知一个队列[1, 3, 6, 9, 7, 3, 4, 6]

  • 按从小到大排序
  • 按从大大小排序
  • 去除重复数字
  1. a = [1, 3, 6, 9, 7, 3, 4, 6]
  2. # 1.sort排序,正序
  3. a.sort()
  4. print(a)
  5. # 2.sort倒叙
  6. a.sort(reverse=True)
  7. print(a)
  8. # 3.去重
  9. b = list(set(a))
  10. print(b)

关于面试总结-python笔试题的更多相关文章

  1. 关于面试总结-python笔试题(递归)

    前言 本篇继续收集一些常见的python笔试题,以基础知识为主,递归是面试最喜欢考的一个问题,不管是做开发还是测试,都无法避免考递归.本篇结合实际案例,讲下几种关于递归的场景. 计算n的阶乘 计算n! ...

  2. 【Python】【面试必看】Python笔试题

    前言 现在面试测试岗位,一般会要求熟悉一门语言(python/java),为了考验求职者的基本功,一般会出 2 个笔试题,这些题目一般不难,主要考察基本功.要是给你一台电脑,在编辑器里面边写边调试,没 ...

  3. 关于面试总结5-python笔试题(递归)

    前言 本篇继续收集一些常见的python笔试题,以基础知识为主,递归是面试最喜欢考的一个问题,不管是做开发还是测试,都无法避免考递归.本篇结合实际案例,讲下几种关于递归的场景. 计算n的阶乘 计算n! ...

  4. python笔试题(1)

            为了充实自己,小编决定上传自己见到的笔试题和面试题.可能要写好长时间,一时半会写不了多少,只能说遇到多少写多少吧,但是只要小编有时间,会持续上传(但是答案却不能保证,所以有看到错误的及 ...

  5. 关于面试总结4-python笔试题

    前言 现在面试测试岗位,一般会要求熟悉一门语言(python/java),为了考验求职者的基本功,一般会出2个笔试题,这些题目一般不难,主要考察基本功. 要是给你一台电脑,在编辑器里面边写边调试,没多 ...

  6. 去蓝港在线面试Unity3D的笔试题。难吗?知道答案的在评论里写出来分享

    前一阵子去蓝港面试unity3d程序,在前台登记以后被领到一个吧台前面填2张个人信息表,之后有人送来笔试题,做了1个小时,感觉挺难的.之后被带到下面面试,面试的是一个年龄稍大的(可能是项目经理或者技术 ...

  7. Python笔试题&面试题总结

    黑色加粗的是笔试题,蓝色是面试题 1.什么是GIL 2.Python中的@staticmethod和@classmethod的区别 (**) 3.Python里面如何拷贝一个对象,并解析深浅拷贝 4. ...

  8. 最新Python笔试题2017 涵盖知识面广泛

    引言 想找一份Python开发工作吗?那你很可能得证明自己知道如何使用Python.下面这些问题涉及了与Python相关的许多技能,问题的关注点主要是语言本身,不是某个特定的包或模块.每一个问题都可以 ...

  9. 传说中的华为Python笔试题——两等长整数序列互换元素,序列和的差值最小(修正)

    有两个序列a,b,大小都为n,序列元素的值任意整形数,无序:要求:通过交换a,b中的元素,使[序列a元素的和]与[序列b元素的和]之间的差最小. 1. 将两序列合并为一个序列,并排序,得到source ...

随机推荐

  1. Help with Intervals(集合的交并补,线段树)

    很早以前做过这题,早就没印象了,估计当时也是照着某大神的代码抄过的,现在是连题意都看了好长时间. 刚开始的S集合是空集,给你一些操作和一个T集合,把操作的结果再赋给S集合. 解法:因为会有开区间和闭区 ...

  2. DDX和DDV——控件与变量之间值的传递

    DoDataExchange由框架调用,作用是交互并且验证对话框数据,主要由(DDX) 和 (DDV)宏实现. 永远不要直接调用这个函数,而是通过UpdateData(TRUE/FALSE)实现控件与 ...

  3. 创建对象js.

    JavaScript中的基本书记类型. Number(数值类型) String(字符串类型) boolean(布尔类型) null(空类型) undefined(未定义类型) object 常见的内置 ...

  4. Objective-C 类型转换

    类型转换通常是指变量,从一种类型转换成另外一种类型.例如将一个long类型转换成int类型,变量转换通常 用下面的方式: (type_name) expression 在Objective-C中,我们 ...

  5. java 序列化Serializable 详解

    Java 序列化Serializable详解(附详细例子) 1.什么是序列化和反序列化Serialization(序列化)是一种将对象以一连串的字节描述的过程:反序列化deserialization是 ...

  6. LR常用函数汇总

    lr_start_transaction为性能分析标记事务的开始 lr_end_transaction为性能分析标记事务的结束 lr_rendezvous在 Vuser 脚本中设置集合点 lr_thi ...

  7. 系统报错undefine not symbol armv7

    libz.dylib libsqlite3.dylib libstdc++.dylib 添加这些动态链接库

  8. sping IOC的设计原理和高级特性

    1. IOC 是Spring的内核,字面意思是控制反转,并提出了DI依赖注入的概念. 2.Spirng 容器的设计中,一个是实现BeanFactory 接口的简单饿汉容器,另外一个是比较高级的Appl ...

  9. DP玄学优化——斜率优化

    --以此博客来悼念我在\(QBXT\)懵逼的时光 \(rqy\; tql\) (日常%\(rqy\)) 概念及用途 斜率优化是\(DP\)的一种较为常用的优化(据说在高中课本里稍有提及),它可以用于优 ...

  10. 关于PHP版本比较函数version_compare的问题

    $version1="v4.0"; $version2="v4.0.0"; print_r(version_compare($version1,$version ...