【填坑系列】Python习题集
求100万以内的所有素数个数
第一种方法
思路:当前数为i,则遍历比int(sqrt(i))+1小的所有数是是否都不可以整除,是,则是素数
理论:如果遍历所有比i小的除数j并且当除数j>int(sqrt(i))时,如果j能整出i,那么必定存在一个小于int(sqrt(i))的数能整出i,因此我们只需只需遍历int(sqrt(i))+1以内的数即可
代码
输出结果如下
第二种方法
理论
- 假如一个整数是合数,则一定存在一个小于它的素数作为其因数。比如9是一个合数,而素数3就是它的一个因数。
- 假如我们知道了小于一个数的所有素数,则只需确定该数能不能被这些素数整除即可。如果不能被整除,则这个数一定是个素数。反之,则不是。
- 也就是说当我们获得一个素数时,可以将它所有的倍数都标记为非素数,这样当我们遍历到一个数时,他没有被任何小于它的素数标记为非素数,则可以确定该数是个素数。
- 比如:从2开始,在初始化时2就是素数。3是类似。遍历到4时,4已经被素数2给标记了,直接跳过
思路
- 初始化一个大范围内的列表,初始时所有数都为素数,遍历时按照以上理论将所有的非素数标记出来即可
代码
输出结果
打印九九乘法表
思路:每一次内层循环j只要循环到外层循环i即可
代码
输出结果如下
求几何级数的第N项
思路
- 几何级数的形式是:
a+a*q+a*q^2+a*q^3+...+a*q^n
- 需要输入的项是:a,q,n
代码
输入输出结果如下
求菲波那切数列的第101位
先写出递推公式再来写实现,递推公式如下
思路
- fib[0]=1 当i=0
- fib[1]=1 当i=1
- fib[i]=fib[i-1]+fib[i-2] 当i>1
- fib的第101位也就是fib[100]=fib[99]+fib[98]
代码
输出结果如下
求杨辉三角第n行第k列的值
字符串转化为数值
描述:把字符串形式的整数或浮点数转化为int或float, 不使用int和float函数
移除一个列表中的重复元素,并保持列表原来的顺序
扁平化字典
例如:
- {‘a’: {‘b’: 1}} 扁平化之后是 {‘a.b’: 1}
- {‘a’: {‘b’: {‘c’: 1, ‘d’: 2}, ‘x’: 2}}扁平化之后是{‘a.x’: 2, ‘a.b.c’: 1, ‘a.b.d’: 2}
初始字典的特点:
- 字典的每个key都是可hash的,因此不会是字典
- 初始字典不为空字典
- 字典的value深度可以无限嵌套
思路:使用递归,每次递归深度都会变化,也就是说路径会变化,可以使用一个path变量记录路径
- 如果嵌套的v不是字典时,直接加入新元素: desDict[‘{}.{}’.format(path, k).lstrip(‘.’)] = v
- 如果嵌套的v为空字典时,直接用空字符串代替: desDict[‘{}.{}’.format(path, k).lstrip(‘.’)] = ‘’
- 如果嵌套的v不为空字典时,直接增长path,并将v进行下一次递归: flatten_dict(v, desDict, path)
- 每一次递归返回时,就说明当前深度的字典已经遍历完毕,需要减短path
- rstrip函数都不是原地修改,返回的都是副本
判断变量是否是字典
- type()
- isInstance()
代码
实现base64编码解码算法
Base64编码的思想
- 采用64个基本的ASCII码字符对数据进行重新编码。它将需要编码的数据拆分成字节数组。以3个字节为一组。按顺序排列24 位数据,再把这24位数据分成4组,即每组6位。再在每组的的最高位前补两个0凑足一个字节。这样就把一个3字节为一组的数据重新编码成了4个字节。当所要编码的数据的字节数不是3的整倍数,也就是说在分组时最后一组不够3个字节。这时在最后一组填充1到2个0字节。并在最后编码完成后在结尾添加1到2个 “=”。
base64编码示例: 将对ABC进行BASE64编码
- 首先取ABC对应的ASCII码值。A(65)B(66)C(67);
- 再取二进制值A(01000001)B(01000010)C(01000011);
- 然后把这三个字节的二进制码接起来(010000010100001001000011);
- 再以6位为单位分成4个数据块,并在最高位填充两个0后形成4个字节的编码后的值,(00010000)(00010100)(00001001)(00000011)
- 再把这四个字节数据转化成10进制数得(16)(20)(9)(3);
- 最后根据BASE64给出的64个基本字符表,查出对应的ASCII码字符(Q)(U)(J)(D),这里的值实际就是数据在字符表中的索引。
base64字符表: 最多六个字节,因此最范围是0~63,所以总共64个字符
- ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/
字符和ascii码之间的转换:单个字符
- ord 字符转换成ascii
- chr ascii转换成字符
字符串和ascii码之间的转换:字符串
- map(ord, “a test String: 123456”)
加密示例
- CBdaF3FV的编码结果是Q0JkYUYzRlY=
- CBdaF34FV的编码结果是Q0JkYUYzNEZW
- CdaF3FV的编码结果是Q2RhRjNGVg==
- ABC的编码结果是QUJD
作用
- 主要用做把二进制转换成字符串
代码1:作为字符串处理
代码2:作为字节数组处理
优点:字节数组+位运算,提高处理速度,减少内存占用。
实现计数器,可以指定基数和步长
生成器和匿名函数的使用
查找两个字符串的最长公共子串
- 暴力法: 找出两个字符串各自所有的子串,然后一一比较,更新最长的值
- 动态规划:
- 两个字符串分别为s1和s2
- s1[i]和s2[j]分别表示其第i和第j个字符(字符顺序从0开始)
- 令L[i, j]表示以s1[i]和s2[j]为结尾的相同子串的最大长度。
- L[i, j] = L[i-1, j-1] + 1 如果s1[i] == s2[j]
- L[i, j] = 0 如果s1[i] != s2[j]
输出结果
实现命令分发器
实现函数可带任意参数(可变参数除外),解析参数并要求用户输入
实现ls命令
实现 -l -a -h 选项
实现find命令
实现 -name -type -ctime -mtime -cnewer -executable -newer -gid -uid 测试
实现cp命令
实现 -r -p选项
实现LinkedList
函数实现
类实现
实现优先队列
函数实现
类实现
实现字典
函数实现
类实现
【填坑系列】Python习题集
https://suncle.me/posts/599780751/