Pyhton与C语言有一定的联系,但要注意一下两种思维方式的不同。
List = [ ]
len(list)
list1 += list2
if x in list:
for x in list:(正序)
for x in list[::-1]:(逆序)
list = [1,2,3,4]
for index, value in enumerate(list):
print(index, value)
0 1
1 2
2 3
3 4
list = [1,2,3,4]
for index, value in enumerate(list,start=2):
print(index, value)
运行结果:
2 1
3 2
4 3
5 4
max(list)
min(list)
sum(list) / len(list)
list.append(X)
list.count(X)
list.extend()
list.index(value)
list.insert(index, value)
>>> list = [1,2,3,4]
>>> list.pop(1)
2
>>> list
[1, 3, 4]
list.remove(value)
list.reverse()
list.sort( key=None,reverse=False)
list.clear()
list.copy()
del list[index]
dict = { }
If key in dict:
len(dict)
dict[key] = value
dict.update({key:value})
>>> d = {1:2,2:3}
>>> d.update({3:4})
>>> d
{1: 2, 2: 3, 3: 4}
>>> d.update({3:5})
>>> d
{1: 2, 2: 3, 3: 5}
字典 get() 函数返回指定键的值,如果值不在字典中返回默认值。
key – 字典中要查找的键。
default – 如果指定键的值不存在时,返回该默认值值。
for key, value in dict.items():
dict.keys()
dict.values()
del dict[key]
del dict
dict.clear()
s = {x1,x2,x3……}
# (创建空集合)
s = set()
s.add(e)
s.remove(e)
s.discard(e)
s.clear()
s.pop()
len(s)
If e in s:
If e not in s:
X – Y
X | Y
X & Y
X ^ Y
例如:(X 包含 Y,Y ⊆ X )
>>> X = {1,2,3,4,5,6}
>>> Y = {2,3,4,5}
>>> X > Y
True
>>> X >= Y
True
>>> X < Y
False
题目描述:
详见
OJ 2522: 咕咕的的复复读读机机
大意:输入n和n个数字,求出现次数最多的数字。
示例代码:
n = int(input())
#输入n
L =list(map(int, input().split()))
#n个数字存入到L列表
print(max(set(L), key = L.count))
#求出出现次数最多的数字
题目描述
详见
OJ 2521: 文本修正
大意:读取一行字符串,如果是单词且是’henan’则变为’Henan’
示例代码:
//s = input().split()
现在的s是存储字符串的列表
s = input().split()
# 读取一行字符串,用空格分隔单词
for i in s:
# 遍历字符串的单词
if i == 'henan':
# 满足条件,改变且输出
print('Henan', end=' ')
else:
print(i, end=' ')
注:今年校赛解出两题且总时长60分钟以内就可以拿奖。
总时长是ACM累加标准。
但是比赛的时候未必能够直接发现这两道题目。省赛也即校赛题目集
If ………:
elif ………:
elif ………:
else ………:
且——或关系
If A and B:
If A or B:
>>> X = 22
>>> if 20 <= X <= 30:
print(X)
22
>>> 20 <= X <= 30
True
If x (not) in s:
If x (not) is s:
循环结构和C语言类似。
for in ……:
else:
while (条件):
else:
思考。循环了几次?
>>> for i in range(6):
i += 3
答案是6次
1、函数代码块以def关键字开头,后接函数表示符名称和圆括号。
2、任何传入参数和自变量必须放在圆括号中间,圆括号之间可以用于定义参数。
3、函数的第一行语句可以选择性地使用文档字符串-用于存放函数说明
4、函数内容以冒号起始,并且缩进
5、return[表达式]结束函数,选择性地返回一个值给调用方,不带表达式的return相当于返回None。
global 保留字
1.位置参数传递
2.关键字传递
关键字(keyword)传递是根据每个参数的名字传递参数。关键字并不用遵守位置的对应关系。
def fun(a,b,c)
return a+b+c
print(f(1,c=3,b=2))
3.参数默认值
在定义函数的时候,使用形如c=10的方式,可以给参数赋予默认值(default)。如果该参数最终没有被传递值,将使用该默认值。
def f(a,b,c=10):
return a+b+c
print(f(3,2))
print(f(3,2,1))
在第一次调用函数f时, 我们并没有足够的值,c没有被赋值,c将使用默认值10.第二次调用函数的时候,c被赋值为1,不再使用默认值。
4.包裹传递/收集参数
可以传递任意个参数
5.解包裹
面向对象最重要的概念就是类(Class)和实例(Instance),必须牢记类是抽象的模板,而实例是根据类创建出来的一个个具体的“对象”,每个对象都拥有相同的方法,但各自的数据可能不同。
封装,顾名思义就是将内容封装到某个地方,以后再去调用被封装在某处的内容。
在类地内部,使用 def 关键字来定义一个方法,与一般函数定义不同,类方法必须包含参数 self, 且为第一个参数,self 代表的是类的实例。
定义父类
子类继承父类
(时间仓促,以上没有涉及的知识点请自己查找相关的资料)
将要自学的内容:
(需要的话再总结)
#字典的get方法
lambda函数用法
format 函数
reduce函数
filter 函数
time库
datetime 库
jieba 库 ->词频统计->词云
文件的使用
正则表达式
关于机器学习算法方面:
线性回归 逻辑回归
KNN(K – 最近邻算法)
支持向量机 朴素贝叶斯
决策树 K-均值算法
随机森林 降维算法
Gradient Boosting 和 AdaBoost 算法