Python学习 —— 阶段综合练习一
Python 阶段综合练习一
综合之前的函数、数据结构、流程控制等,做以下实例练习:(建议先不要看代码,自己先试着写;代码仅供参考,有多种实现方法)
1. 定义 is_Even 函数,传一 int 参数,判断是否是偶数,return True;不是,return False
'''is_Even'''
def is_Even(i):
if(i%2==0):
return True
else:
return False
print(is_Even(0),is_Even(1),is_Even(1))
is_Even
2. 定义 is_Int 函数,传一 float 参数,判断是否是整数(如1.0 即整数),return True;不是,return False
'''is_Int'''
def is_Int(f):
if(f%1==0):
return True
else:
return False
print(is_Int(0),is_Int(1.0),is_Int(1.1))
is_Int'
3. 定义 digital_sum 函数,传一 int 参数,return 其所有位数的数字相加的和;如:1234 返回 10(1+2+3+4); 900 返回 9 (9+0+0)
'''digital_sum'''
def digital_sum(i):
sum = 0
while(i/10>1):
sum += i%10
i = int(i/10)
sum += i
return sum
print(digital_sum(23423),digital_sum(900),digital_sum(0))
digital_sum 1
def digital_sum(i):
i = str(i)
sum = 0
for d in i:
sum += int(d)
return sum
print(digital_sum(23423),digital_sum(900),digital_sum(0))
digital_sum 2
4. 定义 factorial 函数,传一 int 参数,return 其所有位数数字相乘的积;如:1234 返回 24 (1*2*3*4); 909 返回 0 (9*0*9)
'''factorial'''
def factorial(i):
result = 1
while(i/10>1):
result *= i%10
i = int(i/10)
result *= i
return result
print(factorial(1234),factorial(909),factorial(0))
factorial 1
'''factorial'''
def factorial(i):
i = str(i)
result = 1
for d in i:
result *= int(d)
return result
print(factorial(1234),factorial(909),factorial(0))
factorial 2
5. 定义 is_prime 函数,传一 int 参数,判断是否是质数(仅可被1或自己整除),若是,return True;不是,return False; 如:1 返回 True;2 返回 True;4 返回 False;13 返回 True
规定 0 不是质数,返回 False
'''is_prime'''
def is_prime(i):
result = True
for d in range(2,i):
if(i%d==0):
result = False
break
if(i==0):
result = False
return result
print(is_prime(1),is_prime(2),is_prime(3),is_prime(4),is_prime(13),is_prime(197),is_prime(201),is_prime(0))
is_prime
6. 定义 reverse 函数,传一 str 参数,将所有字符串字符倒置并 return 该字符串;如:"abcd" return "dcba"
备注:list.reverse() 及 list[::-1] 可表示 list 倒置
'''reverse'''
def reverse(s):
l = list(s)
new_l = []
for i in range(len(l)-1,-1,-1):
new_l.append(l[i])
return "".join(new_l)
print(reverse("ab cd"),reverse(""))
reverse 1
'''reverse'''
def reverse(s):
l = list(s)
l.reverse() # l = l[::-1]
return "".join(l)
print(reverse("ab cd"),reverse(""))
reverse 2
7. 定义 anti_vowel 函数,传一 str 参数,将字符串中所有的元音(a e i o u) 去除(注意大小写),并return;
如:"Apple is red." return "ppl is rd."
备注:对于list,for item in list_name 即可遍历list,可以不用下标的方式,参见下方的两种方式(之后的例子也列出了两种方式)
'''anti_vowel 1'''
def anti_vowel(s):
l = list(s)
new_l = []
for i in range(len(l)):
if (l[i] not in {'a','e','i','o','u','A','E','I','O','U'}):
new_l.append(l[i])
return "".join(new_l)
print(anti_vowel("Apple is red."))
anti_vowel 1
'''anti_vowel 2'''
def anti_vowel(s):
l = list(s)
new_l = []
for letter in l:
if (letter not in {'a','e','i','o','u','A','E','I','O','U'}):
new_l.append(letter)
return "".join(new_l)
print(anti_vowel("Apple is red."))
anti_vowel 2
8. 定义 scrabble_score 函数,传一 str 参数。预设一组词典(见下方引用),根据词典中字母对应的数值,将传入参数的每个字母数值相加
(非字母不加,注意大小写转换);如:"Word !" 分别对应取 "w": 4 , "o": 1, "r": 1,"d": 2 , 相加为 4+1+1+2 = 8 return 该值
score = {"a": 1, "c": 3, "b": 3, "e": 1, "d": 2, "g": 2, "f": 4, "i": 1, "h": 4, "k": 5, "j": 8, "m": 3, "l": 1, "o": 1, "n": 1, "q": 10, "p": 3, "s": 1, "r": 1, "u": 1, "t": 1, "w": 4, "v": 4, "y": 4, "x": 8, "z": 10}
'''scrabble_score 1'''
def scrabble_score(s):
score = {"a": 1, "c": 3, "b": 3, "e": 1, "d": 2, "g": 2, "f": 4, "i": 1, "h": 4, "k": 5, "j": 8, "m": 3, "l": 1, "o": 1, "n": 1, "q": 10, "p": 3, "s": 1, "r": 1, "u": 1, "t": 1, "w": 4, "v": 4, "y": 4, "x": 8, "z": 10}
l = list(s)
sum = 0
for i in range(len(l)):
letter = l[i].lower()
if letter in score.keys():
sum += score[letter]
return sum
print(scrabble_score("Word !"),scrabble_score("Hello World~!"))
scrabble_score 1
'''scrabble_score 2'''
def scrabble_score(s):
score = {"a": 1, "c": 3, "b": 3, "e": 1, "d": 2, "g": 2, "f": 4, "i": 1, "h": 4, "k": 5, "j": 8, "m": 3, "l": 1, "o": 1, "n": 1, "q": 10, "p": 3, "s": 1, "r": 1, "u": 1, "t": 1, "w": 4, "v": 4, "y": 4, "x": 8, "z": 10}
l = list(s)
sum = 0
for letter in l:
letter = letter.lower()
if letter in score.keys():
sum += score[letter]
return sum
print(scrabble_score("Word !"),scrabble_score("Hello World~!"))
scrabble_score 2
9. 定义 censor 函数,传两个 str 参数:s, h;若 s 字符串中的单词包含 h(全小写)时(不区分大小写,暂时仅考虑空格分隔的单词),
将其隐藏,每个隐藏的字母显示为 *;该方法为不完善的隐藏字符方法,如隐藏字符后有标点,则仍会显示。(若需完善,可用正则表达式,后续学习)
如:censor("Fuck U fuck ... ","fuck") 会 return 字符串为 "**** U **** ... " ;
censor("My qq is: 1000100, pls add my QQ","qq") 会 return 字符串为 "My ** is: 1000100, pls add my **"
备注: str.split(" ") 可根据 " " 分隔字符串并返回为list; 字符串相乘,如 "*"*5 可输出 "*****"
'''censor 1'''
def censor(s,h):
l = s.split(" ")
new_l = []
for i in range(len(l)):
word_l = l[i].lower()
if word_l==h:
new_l.append("*"*len(h))
else:
new_l.append(l[i])
return " ".join(new_l)
print(censor("Fuck U fuck ... ","fuck"))
print(censor("My qq is: 1000100, pls add my QQ","qq"))
censor 1
'''censor 2'''
def censor(s,h):
l = s.split(" ")
new_l = []
for word in l:
if word.lower()==h:
new_l.append("*"*len(h))
else:
new_l.append(word)
return " ".join(new_l)
print(censor("Fuck U fuck ... ","fuck"))
print(censor("My qq is: 1000100, pls add my QQ","qq"))
censor 2
10. 定义 count_i 函数,传两个参数 l, item:l 为一 list,item 为任意类型元素;return l 中包含 i 的个数 ;
如: count_i([1,2,3,4,2,1,3,1.0,"1"],1) 会 return 3 (1.0 也可算入;"1" 不可算入)
count_i(["b","a","ab","a","","A"], "a") 会 return 2
count_i([["a"],"a"], ["a"]) 会 return 1; count_i([["a"],"a"], ["a "]) 会 return 0
'''count_item 1'''
def count_item(l,item):
count = 0
for i in range(len(l)):
if(l[i]==item):
count += 1
return count
print(count_item([1,2,3,4,2,1,3,1.0,""],1))
print(count_item(["b","a","ab","a","","A"], "a"))
print(count_item([["a"],"a"], ["a"]),count_item([["a"],"a"], ["a "]))
count_item 1
'''count_item 2'''
def count_item(l,i):
count = 0
for item in l:
if(item==i):
count += 1
return count
print(count_item([1,2,3,4,2,1,3,1.0,""],1))
print(count_item(["b","a","ab","a","","A"], "a"))
print(count_item([["a"],"a"], ["a"]),count_item([["a"],"a"], ["a "]))
count_item 2
11. 定义 purify 函数,传一 list 参数;去除该 list 中所有的奇数(该list中全为int元素)
如: purify([3,1,5,2,6,1,4]) 会 return [2,6,4]
'''purify 1'''
def purify(l):
l_new = []
for i in range(len(l)):
if(l[i]%2==0):
l_new.append(l[i])
return l_new
print(purify([3,1,5,2,6,1,4]))
purify 1
'''purify 2'''
def purify(l):
l_new = []
for i in l:
if(i%2==0):
l_new.append(i)
return l_new
print(purify([3,1,5,2,6,1,4]))
purify 2
12. 定义 multiple 函数,传可变参数(该参数全为float),return 所有可变参数相乘的积,无参数则返回 None;
如:multiple(3,2) return 6;multiple(3.5,2) return 7.0;multiple(3.5,2,3) return 21.0;multiple(3,2,0,3,) return 0;
备注:函数调用可变个数的参数,在其参数名前加*,如*args,这些参数将被包装进一个元组
'''multiple 1'''
def multiple(*f):
m = 1
if(len(f)==0):
return None
else:
for i in range(len(f)):
m *= f[i]
return m
print(multiple(2,3),multiple(3.5,2),multiple(3.5,2,3),multiple())
multiple 1
'''multiple 2'''
def multiple(*f):
m = 1
if(len(f)==0):
return None
else:
for i in f:
m *= i
return m
print(multiple(2,3),multiple(3.5,2),multiple(3.5,2,3),multiple())
multiple 2
13. 定义 remove_duplicate 函数,传一参数 list,删除 list 中重复的项;
如 remove_duplicate([1,2,3,1.0,1,"1"]) return [1,2,3,"1"]
备注:可用转换为集合set 来去重,但无法保留 list 之前的顺序
'''remove_duplicate 1'''
def remove_duplicate(l):
l_new = []
for i in range(len(l)):
if l[i] not in l_new:
l_new.append(l[i])
return l_new
print(remove_duplicate([1,2,3,1.0,1,""]))
remove_duplicate 1
'''remove_duplicate 2'''
def remove_duplicate(l):
l_new = []
for i in l:
if i not in l_new:
l_new.append(i)
return l_new
print(remove_duplicate([1,2,3,1.0,1,""]))
remove_duplicate 2
'''remove_duplicate 3'''
def remove_duplicate(l):
return list(set(l))
print(remove_duplicate([1,2,3,1.0,1,""]))
remove_duplicate 3
14. 定义 median 函数,传一参数 list,该 list 中元素均为float或int数值;
若 list 长度为奇数,return 该list 最中间的数;若 list 长度为偶数,return 该 list 最中间两个数的平均数;若 list 为空,return none
如 median([3,4,2]) return 3; median([7,2,3,4]) return 3.5 (3+4/2)
备注:须先对 list 排序,用 sorted(list_name)
'''median'''
def median(l):
l = sorted(l)
l_len = len(l)
if l_len == 0:
return None
elif l_len%2 == 1:
return l[int((l_len-1)/2)]
else:
return (l[int((l_len)/2)] + l[int((l_len)/2)-1])/2
print(median([]),median([3,4,2]),median([7,2,3,4]))
median
Python学习 —— 阶段综合练习一的更多相关文章
- Python学习 —— 阶段综合练习三
Python学习 —— 阶段综合练习三 综合之前文件与文件夹操作的学习,做以下实例练习:(建议先不要看代码,自己先试着写:代码仅供参考,有多种实现方法) 1. 目录文件遍历(二层目录结构) 1). ...
- Python学习 —— 阶段综合练习二
综合之前的类的学习,做以下实例练习:(建议先不要看代码,自己先试着写:代码仅供参考,有多种实现方法) 1. Triangle & Equilateral 1). 创建class Triang ...
- Python学习的十个阶段,学完神功大成,对应一下看看你自己在哪个阶段
大家好,我是白云. 今天给大家整理了Python学习的十个阶段内容,看看你现在正处于哪个阶段,想学习的朋友也可以根据这个阶段规划学习. 阶段一:Python基础[ 初入江湖] Linux基础 目标: ...
- 优秀Python学习资源收集汇总(强烈推荐)
Python是一种面向对象.直译式计算机程序设计语言.它的语法简捷和清晰,尽量使用无异义的英语单词,与其它大多数程序设计语言使用大括号不一样,它使用縮进来定义语句块.与Scheme.Ruby.Perl ...
- [转]优秀Python学习资源收集汇总
Python是一种面向对象.直译式计算机程序设计语言.它的语法简捷和清晰,尽量使用无异义的英语单词,与其它大多数程序设计语言使用大括号不一样,它使用縮进来定义语句块.与Scheme.Ruby.Perl ...
- Python之路【第二十四篇】:Python学习路径及练手项目合集
Python学习路径及练手项目合集 Wayne Shi· 2 个月前 参照:https://zhuanlan.zhihu.com/p/23561159 更多文章欢迎关注专栏:学习编程. 本系列Py ...
- python 学习资料
Python是一种面向对象.直译式计算机程序设计语言.它的语法简捷和清晰,尽量使用无异义的英语单词,与其它大多数程序设计语言使用大括号不一样,它使用縮进来定义语句块.与Scheme.Ruby.Perl ...
- 优秀Python学习资源
优秀Python学习资源收集汇总(强烈推荐) Python是一种面向对象.直译式计算机程序设计语言.它的语法简捷和清晰,尽量使用无异义的英语单词,与其它大多数程序设计语言使用大括号不一样,它使用縮 ...
- python学习: 优秀Python学习资源收集汇总--转
Python是一种面向对象.直译式计算机程序设计语言.它的语法简捷和清晰,尽量使用无异义的英语单词,与其它大多数程序设计语言使用大括号不一样,它使用縮进来定义语句块.与Scheme.Ruby.Perl ...
随机推荐
- Hadoop案例(八)辅助排序和二次排序案例(GroupingComparator)
辅助排序和二次排序案例(GroupingComparator) 1.需求 有如下订单数据 订单id 商品id 成交金额 0000001 Pdt_01 222.8 0000001 Pdt_05 25.8 ...
- Js添加、读取、删除cookie,判断cookie是否有效,指定domain域下主路径path下设置cookie,设置expires过期时间
有时我们需要用cookie保存用户名,记录登录状态,如何正确判断该机用户cookie是否存在呢?不能简单使用a!=”这样的写法. 正确方法是:判断是否存在名为username3的cookie,使用do ...
- Mysql Federated Server 示例
Federated存储引擎访问在远程数据库的表中的数据,而不是本地的表.创建一个Federated表的时候,服务器在数据库目录创建一个表定义文件.无其它表被创建,因为实际的数据在一个远程数据库上.这不 ...
- SCU 4442 Party
二分图的最小点权覆盖. 非常感谢巨巨@islands_的解答,还帮我画了一个图. 题目保证给出的边构成的图是一个二分图. 如果没有第三种类型的$frog$,那么问题就很简单了.即选择哪些点,覆盖住所有 ...
- 第10天-JavaScript正则表达式
正则有什么用 给定的字符串是否符合正则表达式的过滤逻辑 通过正则表达式,从字符串中获取我们想要的特定部分 替换字符串满足正则表达式的字符 例如:验证邮箱.手机号.银行卡.采集器(爬虫).中奖信息133 ...
- 【SpringBoot】关闭HttpClient无用日志
环境: SpringBoot pom依赖了apache.commons.HttpClient: <!--httpclient--> <dependency> <group ...
- MySQL笔记(四)之内建函数
AVG() 函数 AVG 函数返回数值列的平均值.NULL 值不包括在计算中. 语法: SELECT AVG(列) FROM 表: COUNT() 函数 COUNT() 函数返回匹配指定条件的行数. ...
- 【BZOJ 3729】3729: Gty的游戏 (Splay维护dfs序+博弈)
未经博主同意不得转载 3729: Gty的游戏 Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 448 Solved: 150 Description ...
- POJ2157 Check the difficulty of problems 概率DP
http://poj.org/problem?id=2151 题意 :t个队伍m道题,i队写对j题的概率为pij.冠军是解题数超过n的解题数最多的队伍之一,求满足有冠军且其他队伍解题数都大于等于1 ...
- FileZilla提权的过程
话不多说,我们直接操作! 首先我们通过 webshell 找到 FileZilla 的文件目录,找到 FileZilla Server Interface.xml 文件,打开.我们可以看到它的连接地址 ...