今天开始学习python,用的教程主要是网上的mooc,为了更好地梳理自己的学习思路,特将一些比较重要的点记录下来。
寻找第n个默尼森数
寻找第n个默尼森数。
代码格式如下:
1 | def prime(num): |
题目内容:找第n个默尼森数。P是素数且M也是素数,并且满足等式$M=2^P-1$,则称M为默尼森数。例如,$P=5,M=2^P-1=31$,5和31都是素数,因此31是默尼森数。
输入格式:用input()函数输入,注意如果Python 3中此函数的返回类型
输出格式:int类型
输入样例:4
输出样例:127
时间限制:500ms内存限制:32000kb
解决方法
思路是通过枚举所有的p(即素数),来寻找第n个默尼森数。初始时刻,设定一定长度的数字列表来寻找素数,然后在素数表中找默尼森数,当找到一个默尼森数,就看看当前的默尼森数是否是第n个。如果在当前素数表中未找到第n个默尼森数,则需要增加素数,继续查找。也就是通过递归的方法,直到找到第 n个默尼森数为止。
代码
1 | # -*- coding: utf-8 -*- |
Python中元组,列表,字典的区别
Python中,有3种内建的数据结构:列表、元组和字典。
1.列表
list是处理一组有序项目的数据结构,即你可以在一个列表中存储一个序列的项目。列表中的项目。列表中的项目应该包括在方括号中,这样python就知道你是在指明一个列表。一旦你创建了一个列表,你就可以添加,删除,或者是搜索列表中的项目。由于你可以增加或删除项目,我们说列表是可变的数据类型,即这种类型是可以被改变的,并且列表是可以嵌套的。
实例:
1 | #coding=utf-8 |
- 对列表的操作,添加,删除,排序结果:
1
2
3
4
5animalslist.append('pig')
del animalslist[0]
animalslist.sort()
for i in range(0,len(animalslist)):
print animalslist[i]1
2
3
4I don't like these 4 animals...
fox tiger rabbit snake
操作后
pig rabbit snake tiger
2.元组
元祖和列表十分相似,不过元组是不可变的。即你不能修改元组。元组通过圆括号中用逗号分隔的项目定义。元组通常用在使语句或用户定义的函数能够安全的采用一组值的时候,即被使用的元组的值不会改变。元组可以嵌套。
1 | >>> zoo=('wolf','elephant','penguin') |
3.字典
字典类似于你通过联系人名称查找地址和联系人详细情况的地址簿,即,我们把键(名字)和值(详细情况)联系在一起。注意,键必须是唯一的,就像如果有两个人恰巧同名的话,你无法找到正确的信息。
键值对在字典中以这样的方式标记:
d = {key1 : value1, key2 : value2
}。注意它们的键/值对用冒号分割,而各个对用逗号分割,所有这些都包括在花括号中。另外,记住字典中的键/值对是没有顺序的。如果你想要一个特定的顺 序,那么你应该在使用前自己对它们排序。
实例:
1 | #coding=utf-8 |
结果:
1 | li 李冰冰 |