python 笔试总结
1、对比两种函数对应结果
def fn(x):
if x>0:
print(x)
fn(x-1)
****结果******
3
2
1
$$$$$$另外一种$$$$$$$$$
def fn(x):
if x>0:
fn(x-1)
print(x)
****结果******
1
2
3
2.简单的方式写下斐波那契数列
1、递推法
def fn(n):
a,b=0,1
for i in range(n+1)
a,b=b,a+b
return a
print(fn(5))
******结果********
8
2、递归法
def fn(n):
if n==1 or n==0:
return 1
return fn(n-1)+fn(n-2)
print(fn(5))
*****结果******
8
3、给出一个整数求各个位的数值
def get_diget(num,i):
return num//(10**i)%10 #各位数i取0
print(get_diget(1314,2))
4、将一个整数变成一个列表
def int2list(num):
li=[]
while num>0:
li.append(num %10) #每次取余数得出最后一位的值加入列表
num= num //10#运算一位后整除10,剩下的num少一位进入下次循环
li.reverse()
return li
print(int2list(13156))
******结果******
[1,3,1,5,6]
5、对整数进行翻转操作(123=>321)
def reverse_int(num):
res=0
while num>0:
res=res*10 #从十位开始每次*10位数增加一位
res+=num % 10 #num %10 得出最后一个的值 加到res
num=num//10 #循环一次num的值少一位
return res
print(reverse_int(123))
****结果******
321
如果输入结果123000 翻转后结果也是321
6、用装饰器写一个计时函数:
装饰器的作用:1、引入日志 2、函数执行时的时间统计 3、执行函数前预备处理 4、执行函数后的清理处理 5、权限校验等场景 6、缓存
def metric(fn):
#空白处 #当装饰器内部调用了__name__等类的方法时候需要在空白处填写@functools.wraps(fn),如果没有调用类的内置方法无需填写
def wrapper(*args,**kwargs):
start=time.time()
func=fn(*args,**kwargs)
end=time.time()
print('运行时间%s'%(end-start)) #print('%s 运行时间 %s s'% (fn.__name__, end-start ))
return func
return wrapper
@metric
def reverse_int(num):
res=0
while num>0:
res=res*10 #从十位开始每次*10位数增加一位
res+=num % 10 #num %10 得出最后一个的值 加到res
num=num//10 #循环一次num的值少一位
return res
print(reverse_int(123))
7 、two sum问题:给定一个整数数组和一个目标值,找出数组中和为目标值的两个数要求返回这两个数所在的位置
第一种两边找方法:时间复杂度o(n) 该方法要求给定的列表要是有序的列表。
def two_sum(li,num):
i=0 #i是轮询查找起始位置
j=len(li)-1 #j为轮询查找最后一个位置
dict={}
for k,v in enumerate(li): #将列表转换为字段,列表的值作为key,列表元素下标做字典的value
dict[v]=k
li_sort=sorted(dict.keys()) #对生成的字典按key进行排序得到排序后的列表
while i<j : #只要i<j 说明轮询查找未结束
s=li_sort[i]+li_sort[j] #列表中两个元素相加的结果
if s==num :
return dict[li_sort[i]],dict[li_sort[j]] #根据得到的值查询得到结果在原始列表的下标
elif s<num :
i+=1 #当两个元素相加值小于要查找的结果时说明前面的数值太小 i的位置向后移动一个位置
elif s>num:
j-=1 #当两个元素相加值大于要查找的结果时说明后面的数值太大 j的位置向前移动一个位置
else:
return -1
b=[8,3,6,9,7,2]
c=two_sum(b,14)
print(c)
****结果*****
(2, 0)
第二种:利用哈希表的方式:时间复杂度0(n)
def two_sum2(li,num):
dict={}
for i in range(len(li)):
a=li[i]
b=num-a
if b not in dict: #检查b是否在字典中,若果没有将值写入字典,直到找到要得到的值
dict[a]=i
else:
return dict[b],i
else:
return -1
b=[8,3,6,9,7,2]
c=two_sum2(b,14)
print(c)
*****结果*****
(0,2)
8、1 and 2 or 3 and 4的结果
在python里面,0,'',[],{},() 和None为假,其它任何东西都为真。
一、and的使用
1 and 2 和 [] and 1
如果没有假值,返回的是最后一个真值,如果有假值,则返回的是第一个假值。
***结果****
2
[]
二、or 的使用
2 or 3 和 [] or 2
如果没有真值,返回的是最后一个假值,如果有真值,则返回的是真值。
***结果****
2
2
三、在不加括号的前提下 and 的优先级大于or
所以 1 and 2 or 3 and 4 运算结果为:
1 and 2 为2 >- 3 and 4 为4 >- 2 or 4 为2
9、利用堆栈的方法做一个括号匹配函数:
def brace_match(n):
stack=[]
dict={'(':')','[':']','{':'}'}
for ch in n:
if ch in ('(','{','[') :
stack.append(ch)
elif len(stack) == 0: #注意判断stack的长度要先与出栈右括号
print('多出一个右括号%s' % ch)
return False
elif dict[stack[-1]]==ch:
stack.pop()
else:
print('括号%s处不匹配'%ch)
if len(stack)==0:
return True
else:
print('剩余左括号未匹配')
return False
10.利用队列读取一个文件的最后n行数据
from collections import deque
q=deque(open('test.txt','r',encoding='utf-8'),5)
原理:设定了固定长度的队列,当读取的时候直接进队出队,直到最后N个数据
例如: q=deque([1,2,3,4,5,6],5)
print(list(q))
***结果****
[2,3,4,5,6] #1由于队列长度限制已经出队,剩余2,3,4,5,6
11、利用python内置方法求差级、交集、并集
a=[1,2,3]
b=[3,4,5]
c=list(set(a)|set(b) #求并集
c=list(set(a)&set(b))#求交集
c=list(set(a)-set(b))#求差级(求差级两个变量位置不同得出的结果不同)
c=list(set(a)^set(b))对称差集(项在a或b中,但不会同时出现在二者中)
*****结果******
[1,2,3,4,5]
[3]
[1,2]
[1,2,4,5]
差集举例
c=list(set(b)-set(a))
结果为[4,5]
12、给定两个有序数组,对这两个数组进行排序
def merge2list(arr1,arr2):
arr=[]
i=0
j=0
while i< len(arr1) and j< len(arr2):
if arr1[i] <= arr2[j]:
arr.append(arr1[i])
i+=1
else:
arr.append(arr2[j])
j+=1
while i< len(arr1):
arr.append(arr1[i])
i+=1
while j< len(arr2):
arr.append(arr2[j])
j+=1
return arr
arr1=[1,3,5,7]
arr2=[2,4,6,8,10]
print(merge2list(arr1,arr2))
13,二分发查找,要求数据为有序数列
def bin_search(data_set,val):
#low 和high代表下标 最小下标,最大下标
low=0
high=len(data_set)-1
while low <=high:# 只有当low小于High的时候证明中间有数
mid=(low+high)//2
if data_set[mid]==val:
return mid #返回他的下标
elif data_set[mid]>val:
high=mid-1
else:
low=mid+1
return # return null证明没有找到
data_set = list(range(100000000))
python 笔试总结的更多相关文章
- 『Python题库 - 填空题』151道Python笔试填空题
『Python题库 - 填空题』Python笔试填空题 part 1. Python语言概述和Python开发环境配置 part 2. Python语言基本语法元素(变量,基本数据类型, 基础运算) ...
- Python 笔试集(4):True + True == ?
目录 目录 前文列表 面试题True Ture 布尔值 布尔类型是特殊的整数类型 前文列表 Python 笔试集:什么时候 i = i + 1 并不等于 i += 1? Python 笔试集(1):关 ...
- Python笔试、面试 【必看】
本文由EarlGrey@编程派独家编译,转载请务必注明作者及出处. 原文:Sheena@codementor 译文:编程派 引言 想找一份Python开发工作吗?那你很可能得证明自己知道如何使用Pyt ...
- Python笔试面试题_牛客(待完善)
中文,免费,零起点,完整示例,基于最新的Python 3版本.https://www.liaoxuefeng.com/wiki/0014316089557264a6b348958f449949df42 ...
- python笔试面试题_视频中(待完善)
一.选择填空题 1. 用一行代码交换a,b的值 a,b = 1,2 print(a,b) a,b = b,a print(a,b) 2. 元祖中有一个元素,有逗号则类型是元祖,无逗号则是远数据类型 t ...
- 以后可得记住了--Python笔试面试题小结
1.字符串处理 将字符串中的数字替换成其两倍的值,例如: 修改前:"AS7G123m (d)F77k" 修改后:"AS14G246m (d)F154k" 个 ...
- Python笔试面试题目及答案
1.is 和==的区别? is:比较的是两个对象的id值是否相等,也就是比较俩对象是否为同一个实例对象.是否指向同一个内存地址 == : 比较的两个对象的内容/值是否相等,默认会调用对象的eq()方法 ...
- Python 笔试集(3):编译/解释?动态/静态?强/弱?Python 是一门怎样的语言
面试题 解释/编译?动态/静态?强/弱?Python 到底是一门怎样的语言? 编译 or 解释? 编译.解释都是指将(与人类亲和的)编程语言翻译成(计算机能够理解的)机器语言(Machine code ...
- Python 笔试集(2):你不知道的 Python 整数
面试题 分别给出下述代码在终端(e.g. IPyhon)中和在程序中的运行结果: a = 256 b = 256 c = 257 d = 257 def foo(): e = 257 f = 257 ...
随机推荐
- SqlServer查询文件组被占用情况
在SqlServer中,删除一个文件组 alter database [xxxxx] remove filegroup FGMonthTurnIntroduceByMonth13 有时候会遇到如下报错 ...
- docker使用centos7系统构建oraclejdk镜像
FROM centos:7.4.1708 MAINTAINER huqiang:2018/10/12 ENV JAVA_VERSION=8 \ JAVA_UPDATE=191 \ JAVA_BUILD ...
- LeetCode Missing Number (简单题)
题意: 给一个含有n个整数的数组,数组中的元素应该是0-n.现在缺了其中某1个,找出缺少的那个整数? 思路: 0-n的总和是可以直接计算的,而缺少的那个就是sum减去数组的和. int missing ...
- linux 命令——17 whereis(转)
whereis命令只能用于程序名的搜索,而且只搜索二进制文件(参数-b).man说明文件(参数-m)和源代码文件(参数-s).如果省略参数,则返回所有信息. 和 find相比,whereis查找的速度 ...
- Android(java)学习笔记83:各种边距设置
1. 各种边距设置: (1)android:layout_paddingLeft 内边距,对谁用,指的是谁的内部内容边距 (2)android:layout_marginLeft 外边距,对谁用,指的 ...
- EM理解(转)
EM是我一直想深入学习的算法之一,第一次听说是在NLP课中的HMM那一节,为了解决HMM的参数估计问题,使用了EM算法.在之后的MT中的词对齐中也用到了.在Mitchell的书中也提到EM可以用于贝叶 ...
- window10启用administrator 和启用组策略编辑器
1,启用administrator账户 net user administrator /active:yes 2,启用组策略编辑器 新建一个文本文件.把下面代码粘贴进去.修改后缀名为.cmd ...
- Java 窗体的基本操作语句 JFrame
package com.swift; import java.awt.Color; import java.awt.GridLayout; import java.util.Random; impor ...
- let和const在es6中的异同点
let和const这两个都是声明一个变量或函数的方法与var差不太多的效果 let的声明在for循环中,当你定义的是多少,最后你的值就是多少开始的,它只进行一次循环,不会像var那样去一遍一遍的去遍历 ...
- Fakeapp 入门教程(1):安装篇!
在众多AI换脸软件中Fakeapp是流传最广,操作最简单的一款,当然他同样也是源于Deepfakes. 这款软件在设计上确实是花了一些心事,只要稍加点拨,哪怕是再小白的人也能学会.下面我就做一个入门教 ...