python-最近面试遇到的代码题,mark一下
1. 打印1000以内的质数
draft版本:
def printlist():
a = []
for i in range(1, 1001):
b.append(i)
for j in range(2, i):
if i % j == 0:
a.remove(i)
break
print(a)
checklist()
稍稍优化一下,把判断是否质数方法独立出来,使用filter或者列表生成器来返回列表
def check(a):
for i in range(2, a):
if a % i == 0:
return 0
return 1
b = list(filter(lambda x:check(x), range(1, 1001)))
c = [x for x in range(1, 1001) if check(x)]
print(b)
print(c)
2. 给定字符串str1和str2,求str1中子串含有str2所有字符串的最小子串长度,若str1不包含所有str2中字符,则返回0,例如str1='abcdeca',str2='ac',则输出3
实现思路:使用字符串的find方法,当字符存在时返回第一次出现的位置,不存在时返回-1。
首先把str2转换成列表,遍历该列表,所有字符在str1中的位置生成新的列表,列表最大值即为符合条件的最小子串长度。
写法一:
def minlength(str1, str2):
lista = list(str2)
listb = []
for item in lista:
x = str1.find(item)+1
if x:
listb.append(x)
else:
return 0
print(max(listb))
minlength('abcdeca', 'ac')
写法二:列表生成器生成新列表
def minlength(str1, str2):
lista = list(str2)
listb = [str1.find(x)+1 for x in lista]
if listb.count(0) > 0:
return 0
else:
print(max(listb))
minlength('abcdeca', 'ac')
3. 统计一个字符串中的词频,按照词频逆序输出
实现思路一:生成集合,然后对集合元素用在原始字符串中的个数倒序排序,使用sorted()方法对集合排序
def reverselist(a):
b = set(a)
c = sorted(b, key=lambda x: a.count(x), reverse=True)
print(" ".join(c))
reverselist('aabcddeeab')
实现思路二:使用collection模块的Counter方法,生成字符串中字符与字符个数的字典,key生成列表,对列表用value值排序
def reverselist(a):
dicta = dict(Counter(a))
b = [x for x in dicta]
b.sort(key=lambda x: dicta[x], reverse=True)
print(" ".join(b))
reverselist('aabcddeeab')
4. 存在某商品的价格列表,列表中是商品每天的价格,要在某一天买入,之后的某一天卖出获得利润,如果没有利润,则返回0
方法一:嵌套循环实现,第一层是买入的价格,第二层是列表该价格之后的价格遍历,计算出每个价格与买入价格的差值,如果大于利润值p,就更新p值
def profit(a):
p = 0
if len(a) < 2:
return 0
for i in a[:-1]:
for j in a[a.index(i)+1:]:
p1 = j-i
if p1 > p:
p1, p = p, p1
if p >0:
return p
else:
return 0
a = profit([5, 5, 2])
print(a)
方法二:截取买入值后的值的子列表,找到最大值,然后把买入值与最大值计算利润,如果大于p就更新p值
def profit1(a):
p = 0
if len(a) < 2:
return 0
for i in a[:-1]:
a1 = a[a.index(i)+1:]
j = max(a1)
p1 = j-i
if p1 > p:
p1, p = p, p1
if p > 0:
return p
else:
return 0
a = profit1([5, 1, 2])
print(a)
说明,遍历列表中的价格时,由于最后一个价格买入时,没有卖出价格,所以列表最后一个值不用遍历。
在第二种写法中,必须遍历a[:-1],否则生成子列表的时候会生成空列表,max()取最大值时会报错,
5. 判断字符串中有没有重复值
解决思路:把字符串转换成集合,然后判断字符串与集合的长度是否相等,由于集合中无重复元素,当长度相等时字符串中也无重复字符,反之则有重复字符
def checkdup(a):
b = set(a)
if len(b) == len(a):
print("无重复字符")
else:
print("有重复字符")
checkdup('aac')
python-最近面试遇到的代码题,mark一下的更多相关文章
- Java面试手写代码题
1.栈实现 2.Iterator实现 3.单例 4.多线和控制(暂停,恢复,停止) 5.生产者消费者
- python面试_总结02_代码题
- 代码题 1.创建一个函数,接收一个字符串参数,判断其做为Python标识符是否合法. 具体要求: 如果合法则输出 True,否则输出 False. 如果该字符串与Python内置的关键字,或Bif ...
- 各位大佬Python的第一部分道基础题已经整理好了,希望大家面试的时候能用的上。
Python的第一部分道基础题,希望大家面试的时候能用的上. 1.为什么学习Python? Python是目前市面上,我个人认为是最简洁.最优雅.最有前途.最全能的编程语言,没有之一. 2.通过什么途 ...
- 2019前端面试系列——JS高频手写代码题
实现 new 方法 /* * 1.创建一个空对象 * 2.链接到原型 * 3.绑定this值 * 4.返回新对象 */ // 第一种实现 function createNew() { let obj ...
- 记搜狗一次不成功的Python后端面试经历
面试搜狗Python后端结束快一个月了,终于有时间来做一个简单的总结了. 简介:工作不久,基础后端岗位,一面结束,失败. 先做了几个笔试题,面试开始会根据笔试题问一些内容.下面将整理一下还能想起来的内 ...
- Android开发面试经——6.常见面试官提问Android题②(更新中...)
版权声明:本文为寻梦-finddreams原创文章,请关注:http://blog.csdn.net/finddreams 关注finddreams博客:http://blog.csdn.net/fi ...
- Android开发面试经——5.常见面试官提问Android题①
版权声明:本文为寻梦-finddreams原创文章,请关注:http://blog.csdn.net/finddreams 关注finddreams博客: http://blog.csdn.net/f ...
- Python自动化面试必备 之 你真明白装饰器么?
Python自动化面试必备 之 你真明白装饰器么? 装饰器是程序开发中经常会用到的一个功能,用好了装饰器,开发效率如虎添翼,所以这也是Python面试中必问的问题,但对于好多小白来讲,这个功能 有点绕 ...
- 实验8、31个最重要的Python Flask面试问题和答案
实验介绍 1. 实验内容 内容涵盖了31个最热门的Flask面试问题,帮助学生更好的理解Flask. 2. 实验要点 了解面试Flask开发人员的常见问题 实验内容 Flask面试问答 Q:Flask ...
- python解析xml模块封装代码
在python中解析xml文件的模块用法,以及对模块封装的方法.原文转自:http://www.jbxue.com/article/16586.html 有如下的xml文件:<?xml vers ...
随机推荐
- SqlServer 联合Update
--1.创建一个备份表: select * into Users_Bak from Users --2.依据某个表进行更新: update Users_Bak set Users_Bak.Mobile ...
- 面试官:介绍一下 Redis 三种集群模式
小码今天去面试. 面试官:给我介绍一下Redis集群, 小码:啊,平时开发用的都是单机Redis,没怎么用过集群了. 面试官:好的,出门右转不谢. 小码内心困惑:在小公司业务量也不大,单机的 Redi ...
- ArcGIS API for JS 访问浏览器提示不安全链接的服务时 如何设置
当我们通过ArcGISServer发布了服务后,首先要在要访问的计算机上通过浏览器访问下服务是否可用.但有时候会出现不安全的标识. 如果这样的链接直接放到代码中,可能会加载失败. 代码如下. var ...
- view-design tabpane禁用后renderHeader失效问题
需求是这样的 在tabPane的renderHeader里面添加hover事件(使用组件自带的Poptip)能显示提示 其实这个不算是问题,设置disabled属性后,原本的元素上面添加了 ivu-t ...
- IOS移动端 -webkit-overflow-scrollin属性造成的问题
-webkit-overflow-scrolling带来的相关问题. -webkit-overflow-scrolling 属性控制元素在移动设备上是否使用滚动回弹效果. 其具有两个属性: auto: ...
- 【机器学习】李宏毅——Flow-based Generative Models
前文我介绍了部分关于生成学习的内容,可以参考我这篇博文点此 前面介绍的各个生成模型,都存在一定的问题: 对于PixelRNN这类模型来说,就是从左上角的像素开始一个个地进行生成,那么这个生成顺序是否合 ...
- JavaScript:变量的作用域,window对象,关键字var/let与function
为什么要将这些内容放在一起,因为他们都跟初始化有关系,我们慢慢说吧. 我们在代码中,都会声明变量.函数和对象,然后由浏览器解释器(下面简称浏览器)执行: 我们还说过,变量和对象的内存结构: 那么,是什 ...
- TiDB上百T数据拆分实践
背景 提高TiDB可用性,需要把多点已有上百T TiDB集群拆分出2套 挑战 1.现有需要拆分的12套TiDB集群的版本多(4.0.9.5.1.1.5.1.2都有),每个版本拆分方法存在不一样 2.其 ...
- 中国蚁剑 - AntSword
中国蚁剑 - AntSword 中国蚁剑是一种跨平台操作工具,它主要提供给用户用于有效的网络渗透测试以及进行正常运行的网站. 否则任何人不得将网站用于其无效用途以及可能的等目的.自己承担并追究其相关责 ...
- Springcloud源码学习笔记1—— Zuul网关原理
系列文章目录和关于我 源码基于 spring-cloud-netflix-zuul-2.2.6.RELEASE.jar 需要具备SpringMVC源码功底 推荐学习https://www.cnblog ...