日期: 2021 年 4 月 16 日

三角形个数

三角形个数(找规律)

1. 问题描述:

%title插图%num

坤坤给你一个边长为n的等边三角形图形,请你查出图形内等边三角形的个数。因为数据过大,所以要求答案对1e9+7取模。

如图是n=2的三角形阵列。我们可以看出有5个三角形。请输出n为20210411时的三角形的个数。
输入描述:
无输入
输出描述:
直接输出
备注:
请直接打印答案即可。

链接:https://ac.nowcoder.com/acm/contest/13493/E
来源:牛客网

2. 思路分析:

对于这种计算集合图形的个数一般是通过观察图形中的分布找出其中的规律,可以发现图中存在正三角形与倒三角形,正三角形是在上一个三角形的基础上增加的个数为(1 + n) * n / 2,倒三角星分为两种情况,*种是n为奇数的情况,那么为n – 1 + n – 3 + …. 0,第二种为偶数的情况为n – 1 + n – 3 + …1,在循环中判断是奇数还是偶数分别计算n为奇数还是偶数的等差数列即可,做这道题目还是做得挺久的,答案是683228996

3. 代码如下:

if __name__ == ‘__main__’:
n = 1
mod = 10 ** 9 + 7
n = 20210412
res = [0] * n
for i in range(1, n):
res[i] = res[i – 1]
res[i] += (1 + i) * i // 2
if i % 2 == 0:
res[i] += (1 + i – 1) * (i // 2) // 2
else:
res[i] += (i – 1) * ((i – 1) // 2 + 1) // 2
res[i] %= mod
print(res[n – 1])

KNN分类算法实现玻璃分类

KNN分类算法实现玻璃分类

机器学习——-KNN分类算法实现玻璃分类
本博客的实验数据是从uci数据集官网上下载下来的(链接: http://archive.ics.uci.edu/ml/datasets/Glass+Identification.)。
(*近在学机器学习,发现机器学习挺有意思的,就大体记录一下。)
首先,机器学习中数据处理占有十分重要的地位。Glass 数据集一共有214条记录,每条记录有10个特征,分别为:Id,RI,Na,Mg,Al,Si,K,Ca,Ba,Fe。 根据这10个特征属性,*终将玻璃划分为building_windows_float_processed,building_windows_non_float_processed,vehicle_windows_float_processed,vehicle_windows_non_float_processed,containers,tableware,headlamps,共7类,其中第4类无数据。
这里对数据的处理很简单,因为下载下来的这个Glass数据集没有缺失,并且都是数值。所以只去除了不需要的Id列,并进行去重处理,得到213条数据。 然后拆分数据集,按照7:3的比例将其随机拆分成训练样本和验证样本。由于数据集的特殊性,本实验将各个类型的数据提取出来,独自按比例拆分。
再来介绍一下KNN算法:
构造KNN分类器的过程:
(1)算距离:通过计算各个训练数据与测试数据之间的距离,按照距离递增关系排序;
(2)找邻居:选取距离*小的K个点,确定K个点所在类别的出现频率;
(3)做分类:返回前K个点中出现频率*高的类别作为测试数据的预测分类。
其中,在计算距离时选择有很多,本实验采用了比较简单的欧氏距离。
使用KNN分类器对训练样本进行模型训练。利用得到的模型对验证样本进行预测,得出预测结果,输出验证正确的样本个数,以及样本准确率。随后,对训练样本和测试样本分别进行可视化。
本实验中选择了两类特征:折射率和Na,进行测试训练。调整K值进行多次分类,选择*好的分类结果,本实验中经过多次测试选择K=17。
在对上述结果进行可视化后,经过分析可知,选取的两个特征值之间的差距有点大,所以在模型训练之前,需要把数据放到同一量级,进行数据预处理。本模型采用了数据归一化的方法,目的是把不一样的特征数据缩放到相同的一个相似区间中。随后,按照相同的步骤进行模型训练,并进行验证。

下面展示代码:

// An highlighted block
#读取数据并分类
def read_dataset():
#读取数据
data=pd.read_csv(“C:/Users/liran/Desktop/glass.data”,header=None) data.columns=[‘Id’,’Rl’,’Na’,’Mg’,’Al’,’Si’,’K’,’Ca’,’Ba’,’Fe’,’Type’]
#删掉不需要的Id列
data.drop(0,axis=1,inplace=True)
#对数据进行去重处理
data.drop_duplicates(inplace=True)
#查看各个类别的玻璃各有多少条记录
#print(data[“Type”].value_counts())
# 拆分数据集,划分为训练样本和验证样本
# 提取出每个类别的数据
t1 = data[data[“Type”] == 1]
t2 = data[data[“Type”] == 2]
t3 = data[data[“Type”] == 3]
t4 = data[data[“Type”] == 4]
t5 = data[data[“Type”] == 5]
t6 = data[data[“Type”] == 6]
t7 = data[data[“Type”] == 7]
# 对每个类别的数据进行洗牌 保证训练样本和测试样本取样方式相同
t1 = t1.sample(len(t1), random_state=0)
t2 = t2.sample(len(t2), random_state=0)
t3 = t3.sample(len(t3), random_state=0)
t4 = t4.sample(len(t4), random_state=0)
t5 = t5.sample(len(t5), random_state=0)
t6 = t6.sample(len(t6), random_state=0)
t7 = t7.sample(len(t7), random_state=0)
# 构建训练集和验证集
#各自截取前70%,除*后列外的列,因为*后一列是y
train_x=pd.concat([t1.iloc[:49,1:3],t2.iloc[:53,1:3],t3.iloc[:12, 1:3], t4.iloc[:0, 1:3], t5.iloc[:9, 1:3],t6.iloc[:6, 1:3], t7.iloc[:5, 1:3]], axis=0)
train_y=pd.concat([t1.iloc[:49, -1], t2.iloc[:53, -1], t3.iloc[:12, -1], t4.iloc[:0, -1], t5.iloc[:9, -1],t6.iloc[:6, -1], t7.iloc[:5, -1]], axis=0)
test_x=pd.concat([t1.iloc[49:,1:3],t2.iloc[53:, 1:3], t3.iloc[12:, 1:3], t4.iloc[0:, 1:3], t5.iloc[9:, 1:3],t6.iloc[6:, 1:3], t7.iloc[5:, 1:3]], axis=0)
test_y = pd.concat([t1.iloc[49:, -1], t2.iloc[53:, -1], t3.iloc[12:, -1], t4.iloc[0:, -1], t5.iloc[9:, -1],t6.iloc[6:, -1], t7.iloc[5:, -1]], axis=0)
return train_x,train_y,test_x,test_y,data
#KNN分类算法
class KNN:
#初始化方法 k:邻居的个数
def __init__(self, k):
self.k = k
#训练方法
# X : [样本数量, 特征数量],待训练的样本特征(属性)
# y : [样本数量],每个样本的目标值(标签)。
def fit(self, X, y):
# 将X转换成ndarray数组
self.X = np.asarray(X)
self.y = np.asarray(y)
#根据参数传递的样本,对样本数据进行预测
# X : [样本数量, 特征数量],待训练的样本特征(属性)
# return:数组类型,预测的结果
def predict(self, X):
X = np.asarray(X)
result = []
# 对ndarray数组进行遍历,每次取数组中的一行。
for x in X:
# 对于测试集中的每一个样本,依次与训练集中的所有样本求距离。
dis = np.sqrt(np.sum((x – self.X) ** 2, axis=1))
# 返回数组排序后,每个元素在原数组(排序之前的数组)中的索引。
index = dis.argsort()
# 进行截断,只取前k个元素。【取距离*近的k个元素的索引】
index = index[:self.k]
# 返回数组中每个元素出现的次数。元素必须是非负的整数。 count = np.bincount(self.y[index], weights=1 / dis[index])
# 返回ndarray数组中,值*大的元素对应的索引。该索引就是我们判定的类别。# *大元素索引,就是出现次数*多的元素。
result.append(count.argmax())
return np.asarray(result)
#绘图展示测试样本,每类数据点以不同的颜色显示
def vision_train(data_x,y):
fig = plt.figure(figsize=(10, 10))
ax = fig.add_subplot(1, 1, 1) # 界面只需显示一个视图
ax.set_title(‘KNN separable data_train set’) #视图名称
plt.xlabel(‘RI-2’) #坐标轴名称
plt.ylabel(‘Na-3’)
type1_x = []
type1_y = []
type2_x = []
type2_y = []
type3_x = []
type3_y = []
type4_x = []
type4_y = []
type5_x = []
type5_y = []
type6_x = []
type6_y = []
type7_x = []
type7_y = []
colors = [‘r’,’g’,’b’,’y’,’k’,’m’,’c’] #定义显示的颜色
#查找样本对应类型的索引
for i in range(213):
#防止list index out of range的错误,使用try except
try:
if (y[i] == 1):
type1_x.append(data_x.iloc[i,0])
type1_y.append(data_x.iloc[i,1])
elif (y[i] == 2):
type2_x.append(data_x.iloc[i, 0])
type2_y.append(data_x.iloc[i, 1])
elif (y[i] == 3):
type3_x.append(data_x.iloc[i, 0])
type3_y.append(data_x.iloc[i, 1])
elif (y[i] == 4):
type4_x.append(data_x.iloc[i, 0])
type4_y.append(data_x.iloc[i, 1])
elif (y[i] == 5):
type5_x.append(data_x.iloc[i, 0])
type5_y.append(data_x.iloc[i, 1])
elif (y[i] == 6):
type6_x.append(data_x.iloc[i, 0])
type6_y.append(data_x.iloc[i, 1])
else:
type7_x.append(data_x.iloc[i, 0])
type7_y.append(data_x.iloc[i, 1])
except:
continue
ax.scatter(type1_x,type1_y,marker=’o’,color=’r’, label=’building_windows_float_processed’,s=10)
ax.scatter(type2_x,type2_y,marker=’o’,color=’g’, label=’building_windows_non_float_processed’, s=10)
ax.scatter(type3_x,type3_y,marker=’o’,color=’b’, label=’vehicle_windows_float_processed’, s=10)
ax.scatter(type4_x,type4_y,marker=’o’,color=’y’, label=’vehicle_windows_non_float_processed’, s=10)
ax.scatter(type5_x,type5_y,marker=’o’,color=’k’, label=’containers’, s=10)
ax.scatter(type6_x,type6_y,marker=’o’,color=’m’, label=’tableware’, s=10)
ax.scatter(type7_x,type7_y,marker=’o’,color=’c’, label=’headlamps’, s=10)
plt.legend(loc = ‘upper right’) #图例显示位置
plt.show()
#验证样本可视化
def vision_test(test_x,test_y,result):
right = test_x[result == test_y]
wrong = test_x[result != test_y]
fig = plt.figure(figsize=(10, 10))
ax = fig.add_subplot(1, 1, 1) # 界面只需显示一个视图
ax.set_title(‘KNN separable data_test set’) # 视图名称
plt.xlabel(“RI-2”)
plt.ylabel(“Na-3″)
ax.scatter(x=right.iloc[:, 0], y=right.iloc[:, 1], color=’r’, marker=”x”, label=”right”,s=10)
ax.scatter(x=wrong.iloc[:, 0], y=wrong.iloc[:, 1], color=”m”, marker=”>”, label=”wrong”,s=10)
plt.legend(loc=”upper right”)
plt.show
# 归一化特征值 特征缩放
def autoNorm(dataSet):
#求*大值和*小值
#X_new=(x-min)/(max-min)
minVals = dataSet.min(0)
maxVals = dataSet.max(0)
ranges = maxVals – minVals
normDataSet = np.zeros(np.shape(dataSet))
m = dataSet.shape[0]
normDataSet = dataSet – np.tile(minVals, (m, 1))
normDataSet = normDataSet / np.tile(ranges, (m, 1))
return normDataSet, ranges, minVals
def main():
#读取数据
train_x,train_y,test_x,test_y,data = read_dataset()
# 创建KNN对象,进行训练和验证
knn = KNN(k=17)
# 进行训练
knn.fit(train_x, train_y)
# 进行验证
result = knn.predict(test_x)
#输出测试正确个数及正确率
print(sum(result == test_y))
print(sum(result == test_y)/len(result))
#pandas读取的数据要转换成list之后再进行查找索引操作
trainy = train_y.values.tolist()
#进行可视化
#训练样本可视化
#vision_train(train_x,trainy)
#测试样本可视化
#vision_test(test_x,test_y,result)
#归一化处理数据
data_x,ranges,minVals=autoNorm(train_x)
knn1 = KNN(k=17)
knn1.fit(data_x,train_y)
result = knn1.predict(test_x)
# 输出测试正确个数及正确率
print(sum(result == test_y))
print(sum(result == test_y) / len(result))
#归一化后的可视化
vision_train(data_x,trainy)

if __name__ == ‘__main__’:
main()

虚拟化是什么,虚拟化技术分类

什么是虚拟化?

这里简单归纳一下我的理解:

1.虚拟化是资源的一种逻辑表示,并不会受限于物理资源。

2.运行的环境不在真实的硬件上,而是硬件之上的虚拟内存中的一段,或者说是虚拟的环境中。

3.虚拟化为数据、计算能力、存储资源等提供了一个逻辑视图,而不是物理视图。

4.虚拟化的发展,大幅降低了IT硬件成本,减少了资源的浪费,并且提升了系统的稳定性和安全性。

全虚拟化

全虚拟化(FullVirtualization)也称为原始虚拟化技术,该模型使用虚拟机协调Guest操作系统和原始硬件,VMM在Guest操作系统和裸硬件之间用于工作协调,一些受保护指令必须由Hypervisor(虚拟机管理程序)来捕获处理。全虚拟化的运行速度要快于硬件模拟,但是性能方面不如裸机,因为Hypervisor需要占用一些资源。

半虚拟化

半虚拟化(ParaVirtualization)是另一种类似于全虚拟化的技术,它使用Hypervisor分享存取底层的硬件,但是它的Guest操作系统集成了虚拟化方面的代码。该方法无需重新编译或引起陷阱,因为操作系统自身能够与虚拟进程进行很好的协作。半虚拟化需要Guest操作系统做一些修改,使Guest操作系统意识到自己是处于虚拟化环境的,但是半虚拟化提供了与原操作系统相近的性能。

虚拟化技术的关键特性

同质-Equivalence

即VM的运行环境和物理机的环境在本质上是相同的,表现上允许有一些差异。如CPU的桥片必须一致,CPUcore的个数以及内存可以不同,不必使用同类型的网络适配器驱动等等。

高效-Efficiency

即VM的性能必须接近物理机。因此,常见的虚拟系统模拟器(Boches,simics等)就不能成为VM。为达此目的,软件在虚拟系统上运行时,大多数指令要直接运行在硬件上执行,只有少量指令需要VMM的模拟或翻译处理。

资源受控-Resourcecontrol

即VMM(VirtualMachineMonitor)对物理机的所有资源有*对的控制力。虚拟机不允许直接执行敏感指令。

云计算的定义、本质、技术和未来

云计算

云计算是一种以互联网为基础的计算技术,在这里使用者看不见电脑,而计算的能力是按需供给的,就像电力在需要时按需求量输送给每家每户一样。

2006年8月9日,当时Google的CEO施密特在搜索引擎大会上首次提出了“云计算”(Cloud Computing)的概念。从那个时候起,云计算一直是IT界炙手可热的概念。

(1) 云计算的发展历程

云计算*早可以追溯到甲骨文公司的CEO埃里森在上世纪90年代提出的“网络电脑”的概念。为了和微软竞争,埃里森提出了“网络电脑”的新思想,试图将用户对客户端的需求降到*低。但由于当时用户上网的费用较高,并且在客户端的大部分软件在互联网上没有相应的服务,因此“网络电脑”没有做成功。

到2002年之后,Google迅速崛起,它开始提供替代各种客户端应用和服务的在线服务。此外,在2002年之后,WiFi技术迅速普及,人们上网已经非常的方便了,随时随地访问、处理和共享信息的需求就变得越来越重要了。这样,云计算的概念就诞生了。

Google、IBM和亚马逊在2005年提出了云计算的概念,全球各大IT公司积*响应,纷纷提出了自己的云计算服务。

(2) 云计算的本质

综合各大公司的云计算的特点,我们可以看出云计算的本质是这样的:

首先,云计算保证用户可以随时随地访问和处理信息,并且可以非常方便地与他人共享信息。

其次,云计算保证用户可以使用大量的在云端的计算资源,包括处理器CPU和存储器(内存和磁盘),而无需自己购买设备。

(3) 云计算的关键技术

云计算要想在社会上普及,需要过技术、工程和法律等多道关卡。其中涉及到的关键技术包括:存储、资源管理和信息安全。

在存储方面,主要包括海量数据的存储和结构化数据的存储。资源管理就是将成千上万台服务器组织在一起,让使用者觉得远程使用云计算的资源就像使用自家的计算机一样。信息安全技术是云计算能否普及的关键。

(4) 云计算的未来

云计算发展至今,已经对IT产业链造成了颠覆,新的产业链将逐渐形成。IT产业链的变化主要表现在这几个方面:

*,随着WinTel(Windows加Intel)体系的日渐式微,一大批公司的核心业务将受到严重的挑战。

第二,硬件厂商的产品线将进行非常大的调整。

第三,随着计算终端市场的变迁,对应的外设市场也开始发生变化。

第四,由于用户终端要和云端的服务器通信,那么浏览器的重要性日益显现。

云计算的发展是全社会的事情,需要公开的标准和服务。但不管如何,云计算发展的大潮不可阻挡。尽管现在有很多公司打着云计算的大旗刻意炒作概念,但那些坚持在云计算的基本技术和真正的应用上投入的公司,将成为笑到*后的赢家。

当然,尽管云计算已被越来越多的公司和个人所接受,但它的普及还需要在技术上进一步完善,更为重要的是在法律上要有完善的保障。即便如此,云计算的浪潮不可阻挡。

request基本使用教程

request基本使用教程

request使用
一.基本用法
1.准备工作安装request库,pip安装或再pycharm内安装。
2.实例引入renquest库中方法清晰简单,获取网页直接使用get方法就能直接实现:

代码:

import requests
response = requests.get(‘http://www.baidu.com/’)
print(type(response))
print(response.status_code)
print(type(response.text))
print(response.cookies)

运行结果:

<class ‘requests.models.Response’>
200
<class ‘str’>
<RequestsCookieJar[<Cookie BDORZ=27315 for .baidu.com/>]>

request中我们使用其他方法也很简单:

r = request.post(‘url/post’)
r = request.put(‘url/put’)
r = request.delete(‘url/delete’)
r = request.head(‘url/get’)
r = request.post(‘url/get’)

**3.**GET请求
http中*常见的请求是get请求,对get请求进行详解。
首先是一个简单的get的请求,请求一个链接http://httpbin.org/get,该网站会判断如果客户端发起get请求的话,它会返回相应信息:
这是一个专门测试的网站 http://httpbin.org/

import requests
response = requests.get(‘http://httpbin.org/get’)
print(response.text)

运行结果:

{
“args”: {},
“headers”: {
“Accept”: “*/*”,
“Accept-Encoding”: “gzip, deflate”,
“Host”: “httpbin.org”,
“User-Agent”: “python-requests/2.25.1”,
“X-Amzn-Trace-Id”: “Root=1-6076af01-5222d2ca535f9b6039280a85”
},
“origin”: “18.167.102.111”,
“url”: “http://httpbin.org/get”
}

可以看到我们发起了请求,返回的结果能看到我们的请求头,链接,ip等信息。
我们还可以向get请求中传入参数,构造一个附加额外信息的get请求。
直接构造:

r = request.get(‘http://httpbin.org/get?name=germey&age=22’)
1
?后面接参数开始 &连接参数,显然这样太复杂因此我们引入params参数。
params参数示例:

import requests
data = {
‘name’: ‘germey’,
‘age’: ’22’
}
response = requests.get(‘http://httpbin.org/get’,params=data)
print(response.text)

运行结果:

{
“args”: {
“age”: “22”,
“name”: “germey”
},
“headers”: {
“Accept”: “*/*”,
“Accept-Encoding”: “gzip, deflate”,
“Host”: “httpbin.org”,
“User-Agent”: “python-requests/2.25.1”,
“X-Amzn-Trace-Id”: “Root=1-6076b273-24b1eebd6542e66659560793”
},
“origin”: “18.167.102.111”,
“url”: “http://httpbin.org/get?name=germey&age=22”
}

根据控制台返回的信息我们知道request已经自动为我们构造了一个url链接。我们还可以调用json方法,将字符串类型的json格式转换为字典类型的json。

print(response.json)
1
抓取网页
我们以知乎为例来抓取知乎的界面信息

import requests
import re
headers = {
‘cookie’: ‘填入你的cookies’,

‘user-agent’: ‘Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.100 Safari/537.36’
}
r = requests.get(‘https://www.zhihu.com/’, headers=headers)
print(r.text)
print(r.status_code)

抓取二进制数据
我们抓取了一个知乎界面但其实我们知道它是一个html文档,如果我们向抓取二进制数据图片、视频、音频又应该怎么办呢。
我们以知乎的图标为例:

import requests
import re
headers = {
‘cookie’: ‘填入你的cookies’,

‘user-agent’: ‘Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.100 Safari/537.36’
}
r = requests.get(‘https://static.zhihu.com/heifetz/assets/apple-touch-icon-152.a53ae37b.png’, headers=headers)
print(r.text) # 直接打印会乱码 因为将二进制强制以字符格式输出
with open(‘zhihu.png’,’wb’) as f : # 写入本地可再与.py文件相同的地址查看图片
f.write(r.content)

4.post请求
我们了解了*基本的get请求,post也是应该常见的请求方式,就是把相关信息返回。

import request
data = {‘name’: ‘germey’, ‘age’: ’22’}
r = requests.post(‘http://httpbin.org/post’,data=data)
print(r.text)

运行结果:

{
“args”: {
“age”: “22”,
“name”: “germey”
},
“headers”: {
“Accept”: “*/*”,
“Accept-Encoding”: “gzip, deflate”,
“Host”: “httpbin.org”,
“User-Agent”: “python-requests/2.25.1”,
“X-Amzn-Trace-Id”: “Root=1-6076f804-446c1b1d538e216f066e33ee”
},
“origin”: “111.17.194.60”,
“url”: “http://httpbin.org/get?name=germey&age=22”
}

我们可以看到数据的提交。
5.响应

import requests
headers = {
‘cookie’: ‘url’,
‘user-agent’: ‘Mozilla/5.0 (Windows NT 10.0; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/69.0.3497.100 Safari/537.36’
}
r = requests.get(‘https://www.zhihu.com/’, headers=headers)
print(‘状态码:’,r.status_code)
print(‘请求头:’,r.headers)
print(‘cookies:’,r.cookies)

运行结果:

状态码: 200
请求头: {‘Server’: ‘CLOUD ELB 1.0.0’, ‘Date’: ‘Wed, 14 Apr 2021 14:18:07 GMT’, ‘Content-Type’: ‘text/html; charset=utf-8’, ‘Vary’: ‘Accept-Encoding’, ‘set-cookie’: ‘tst=; path=/; expires=Thu, 01 Jan 1970 00:00:00 GMT; httponly, KLBRSID=ed2ad9934af8a1f80db52dcb08d13344|1618409886|1618409886; Path=/’, ‘content-security-policy’: “default-src * blob:; img-src * data: blob: resource: t.captcha.qq.com cstaticdun.126.net necaptcha.nosdn.127.net; connect-src * wss: blob: resource:; frame-src ‘self’ *.zhihu.com mailto: tel: weixin: *.vzuu.com mo.m.taobao.com getpocket.com note.youdao.com safari-extension://com.evernote.safari.clipper-Q79WDW8YH9 zhihujs: captcha.guard.qcloud.com pos.baidu.com dup.baidustatic.com openapi.baidu.com wappass.baidu.com passport.baidu.com *.cme.qcloud.com vs-cdn.tencent-cloud.com t.captcha.qq.com c.dun.163.com; script-src ‘self’ blob: *.zhihu.com g.alicdn.com qzonestyle.gtimg.cn res.wx.qq.com open.mobile.qq.com ‘unsafe-eval’ unpkg.zhimg.com unicom.zhimg.com resource: captcha.gtimg.com captcha.guard.qcloud.com pagead2.googlesyndication.com cpro.baidustatic.com pos.baidu.com dup.baidustatic.com i.hao61.net ‘nonce-395681d5-2009-4f24-ba9b-2f4de9719d15’ hm.baidu.com zz.bdstatic.com b.bdstatic.com imgcache.qq.com vs-cdn.tencent-cloud.com ssl.captcha.qq.com t.captcha.qq.com cstaticdun.126.net c.dun.163.com ac.dun.163.com/ acstatic-dun.126.net; style-src ‘self’ ‘unsafe-inline’ *.zhihu.com unicom.zhimg.com resource: captcha.gtimg.com ssl.captcha.qq.com t.captcha.qq.com cstaticdun.126.net c.dun.163.com ac.dun.163.com/ acstatic-dun.126.net”, ‘x-frame-options’: ‘SAMEORIGIN’, ‘strict-transport-security’: ‘max-age=15552000; includeSubDomains’, ‘surrogate-control’: ‘no-store’, ‘cache-control’: ‘no-cache, no-store, must-revalidate, private, max-age=0’, ‘pragma’: ‘no-cache’, ‘expires’: ‘0’, ‘x-content-type-options’: ‘nosniff’, ‘x-xss-protection’: ‘1; mode=block’, ‘X-Backend-Response’: ‘0.435’, ‘Referrer-Policy’: ‘no-referrer-when-downgrade’, ‘X-SecNG-Response’: ‘0.43999981880188’, ‘X-UDID’: ‘AFDupPWGbBCPTjG_3TfIUhnlEgcac_LzB2M=’, ‘x-lb-timing’: ‘0.441’, ‘x-idc-id’: ‘2’, ‘Content-Encoding’: ‘gzip’, ‘Transfer-Encoding’: ‘chunked’, ‘X-NWS-LOG-UUID’: ‘7093856299592433989’, ‘Connection’: ‘keep-alive’, ‘X-Cache-Lookup’: ‘Cache Miss’, ‘x-edge-timing’: ‘0.462’, ‘x-cdn-provider’: ‘tencent’}
cookies: <RequestsCookieJar[<Cookie KLBRSID=ed2ad9934af8a1f80db52dcb08d13344|1618409886|1618409886 for www.zhihu.com/>]>

网络通信常见加密剖析

网络通信常见加密剖析

当人类面对荒蛮外界时,人身安全是*需求,人们需要相互传授安全防范的经验和技能。当人类步入信息社会之时,我们不难发现信息安全还是我们的*需求,而且现在比过去任何时候都更需要普及信息安全的意识和知识。
——《密码学》序,某不具名的中国科学院成都计算机应用研究所研究员/博导

在不懂计算机的人眼里,黑客们几乎都是离群索居、脾气古怪,在赛博世界中无孔不入无所不能的代名词——这当然不是真的,而且*大多数要归功于编剧们的奇思妙想。造成这种误差有很大一部分来自人们并不了解这个赛博空间中相当重要的一环:网络安全。
人们总认为黑客的技术晦涩难懂且充满神秘,其实不然(当然,申必代码倒是有)。但是网络通信加解密有什么手段、什么意思、出自哪里呢?今天小编就带大家来了解一下网络通信中常见的两类加密方式:对称加密和非对称加密

基础概念
Hash
既然今天挑了加解密作为我们讨论的重点,那自然要先讲一下Hash了~
Hash,音译叫哈希,也可以叫做散列,是一种生成信息摘要的方式。我们都知道计算机是以二进制储存数据的,而所有的二进制都是一个数字,Hash所做的就是将这样一个数字通过计算,得出一个固定长度的消息摘要,这样的消息摘要大致上具有两个特性:不可逆、低碰撞。不可逆的意思很好理解:用Hash处理过的消息摘要无法再还原至消息本身,也就相当于是一个单向的加密过程(而且几乎无法解密)。低碰撞的意思指的则是两条不同的消息要尽可能地不会得到同一个Hash(不过在这点上,有些Hash算法偏重一点点差距就会造成巨大的差异(但是相应的,两个不同文件碰撞的可能会变大),而另一些算法则侧重于两个不同文件更不可能碰撞)。
Tips:Hash并不是某种特定的算法,而是一类具有相同思想和特性的算法的统称,常见的Hash算法包括MD5、SHA-1等。

常见术语解释
明文
指原始的消息,理想状态下只有发送/接收方能看到明文,但这一点很难实现,所以大家多采用传输加密密文的方式来保证安全性,在数据加解密中属于不能暴露的信息。

密文
指加密后的消息,密文*重要的一个特性就是没有秘钥就无法解密,因此网络通信中常见的加解密主要关注于密钥,在数据加解密中属于可以暴露的信息。

密钥
指的是一个控制加密/解密过程的标志型信息(数字、字符串和其他信息),根据算法的不同,密钥还有可能分为通用密钥、加密密钥和解密密钥等,,在数据加解密中属于基本不能暴露的信息。

算法
指的是加密/解密的过程,将一段信息通过某个密钥进行演算从而得出,在数据加解密中属于*好不要暴露的信息,但好的加密算法及加密体系应当确保即便算法暴露也无法解密密文。

关于安全性
需要注意的是,无论是何种算法都不能抵挡无敌的穷举法,但我们更期望于尽可能地延长被破解的时间——试想,如果你的手机号需要一千年才能被超算解密,难道这种算法就是不安全的吗?恰恰相反,在实际应用中,我们注重的并非完全的难以破解——这不可能,我们注重的是提高入侵者的攻击成本,从而达到阻止破解的目的。

对称加密
对称加密可称得上是*古老的加密形式:通过一套加密/解密过程和一把密钥,对密文进行的操作和对明文的进行的操作都可以被复现——就好像你家的门锁,只要有一把钥匙,无论是谁都能将它锁上、无论是谁都能将它打开。
*简单的对称加密当属古老的凯撒密码,将一串字母中的某几位替换成后几个字母(如A变成C,B变成D),解密的时候只要知道向后了几位便可以还原密文——在那个没有计算机的时代,这种密码还算符合军事加密通信的要求,可在计算机性能日新月异的当代,这种密码就不够看了。但*令人头疼的不是该种算法容易被暴力破解——在现代,对称加密技术在密钥不泄漏的情况下可以称是*安全、*高效的加密手段(例如DES、AES乃至3DES等,这里限于篇幅不再展开详细讨论算法)。唯一的问题是,在网络通信中,我们一贯假设通信是被侦听的、甚至有可能被篡改,因此如何安全地传递密钥就变成了一个鸡生蛋还是蛋生鸡的问题。为此,人们又设计出了非对称加密算法。

非对称加密
提及非对称加密,不得不说的就是RSA算法,这是一种典型的非对称加密算法,这类算法*大的特征就是加密密钥和解密的密钥并不是同一把密钥,所以服务器可以公开自己的加密密钥,任何人都可以使用这把钥匙加密数据(我们称公开的密钥为公钥,私有的密钥为私钥),但只有服务器自己可以解密这把公钥加密的数据——即服务器自己持有的私钥并不需要暴露就可以独立进行加密,这就保证了服务器接收到的数据是未被篡改且不会被侦听的。
非对称加密算法的唯一的问题就是他们的速度相较对称加密算法来说要慢上许多——甚至可以说是在高性能要求的场景下不可被接受的延迟。

端对端通信
综上所述,对称加密算法的问题在于密钥不可信,而非对称加密算法的问题在于不能支持大量数据的流动,因此聪明的你肯定马上可以想到:我们可以利用非对称算法传递一个对称密钥,然后如此通信啊!
对,完全没错,这就是端对端通信中的加密手段,客户端首先向服务器请求一个公钥——这不需要加密,因为公钥本来就是暴露的,然后由这把公钥加密自己的对称密钥/加密公钥并传输给服务器,服务器再用自己的私钥进行解密:这就是大名鼎鼎的SSL。
注:SSL在工作流程上还有一些为了防止攻击和保证数据完整性做的额外努力,但大体思路如此。

证书签名
好的,一切看起来都很完美,但是有一个小问题:如果我们的数据被篡改了怎么办?
假设客户端和服务器中间有一个转发者,他截获了客户端发出的请求并将自己的公钥返回给了客户端,然后再将客户端的请求发给了服务器,客户端用攻击者的密钥加密了自己的对称密钥——但私钥却不在服务器,而是在攻击者手里,很显然这条连接将是一条裸奔的加密连接——而且双方都对此毫不知情,这该怎么办呢?
现代的安全专家们采用了一个非常巧妙的方式来解决这个问题:他们重新构建了另一套非对称密钥(为了方便和上面的连接密钥区分,我们称其为证书密钥),这套非对称密钥中的公钥是解密用的密钥,而私钥(即加密密钥)掌握在服务器自己手里。
这样,当其他人询问的时候,服务器就会将传输密钥、身份信息组合成一个字符串,然后将计算它的哈希并它加密,*后将密文和哈希同时打包发送——这证明了打包者同时知晓原文和密钥,原因如下:
1.因为只有原文才能得出哈希,而哈希本身不可逆,所以得到哈希者必然需要知道原文/哈希中的一条。
2.因为非对称密钥中加密密钥和解密密钥相对应,如果能成功解码消息则起码证明发送密文者知晓密钥和原文。
我们常说“孤证不立”,在密码学中也有类似的说法,即“单一信息无法验证自己是否可信”,读者们可以自己思考一下为什么一定要哈希和密文同时发送才能证明密文发送者是服务器(即一定持有加密用的证书私钥)。
在这种情况下,只要我们确保解密用的解密密钥可信,我们就可以确保和我们通信的一定是这个解密密钥对应的加密密钥——即一定是这台服务器。
但很显然,我们没有办法保证解密密钥的可信,*后解决这个问题的办法是我们提前在计算机里设置一些*对可信的解密密钥,当我们遇到一个声称“自己安全”的解密密钥时,便去询问这些服务器,由他们来证明这个解密密钥安全。这些密钥、还有一些额外的信息(比如密钥哈希、身份等)一起打个包,就变成了我们熟知的数字证书。

结语
好的,那么这就是小编给大家分享的网络通信加解密有什么手段、什么意思、出自哪里。希望大家看完这篇由小编精心整理的内容后,能对相关知识有所了解,解决你的困惑!(狗头保命)

pytorch版的bert分类模型流程

pytorch版的bert分类模型流程

文章目录
pytorch版的bert分类模型流程,后加bert_BiLSTM融合对比
一.前言
版本详述
数据预处理
定义模型参数
预训练模型下载 放在bert_model 包含config.json,pytorch_model.bin,vocab_txt
二.完整代码github链接
三.上代码
import
1.预处理数据
2.定义bert模型
3.定义优化器和线性学习率
4.定义训练函数和验证测试函数
5.开始训练
6.加载*优模型进行测试
完整代码Github链接
pytorch版的bert分类模型流程,后加bert_BiLSTM融合对比
一.前言
版本详述
python 3.6
pytorch 1.7
transformers 4.3.3
一块GPU,2次EPOCH训练时间不超30min

数据预处理
数据分train,dev,test,三个txt文件
转换数据格式
设置分批训练
打乱数据顺序

定义模型参数
batch_size 64
max_len 30
device cuda
epochs 2 (自己可修改多轮训练尝试,2轮训练正确率结果94.9%)

预训练模型下载 放在bert_model 包含config.json,pytorch_model.bin,vocab_txt
git clone https://huggingface.co/bert-base-chinese
1
二.完整代码github链接
https://github.com/young-yhx/bert_classify

三.上代码
import
import pandas as pd
import numpy as np
import json,time
from tqdm import tqdm
from sklearn.metrics import accuracy_score,classification_report
import torch
import torch.nn as nn
import torch.nn.functional as F
import torch.optim as optim
from torch.utils.data import TensorDataset,DataLoader,RandomSampler,SequentialSampler
from transformers import BertModel,BertConfig,BertTokenizer,AdamW,get_cosine_schedule_with_warmup

#参数
bert_path = ‘bert_model/’ #预训练模型的位置
tokenizer = BertTokenizer.from_pretrained(bert_path) #初始化分词器
max_len = 30 #数据阻断长度
BATCH_SIZE = 64
DEVICE = torch.device(“cuda” if torch.cuda.is_available() else “cpu”)
EPOCHS = 2

1.预处理数据
1.1处理数据成input_ids,token_type_ids,attention_mask,label
def dataSet(data_path):
input_ids,token_type_ids,attention_mask = [],[],[]
labels = []
with open(data_path,encoding=’utf-8′) as f:
for i,line in tqdm(enumerate(f)):
title,y = line.strip().split(‘\t’) #删除所有的空格,用\t分割数据集和标签
#调用tokenizer转换成bert需要的数据格式
encode_dict = tokenizer.encode_plus(text=title,max_length=max_len,padding=’max_length’,truncation=True)
#分别获取三个值 目前值的类型为list
input_ids.append(encode_dict[‘input_ids’])
token_type_ids.append(encode_dict[‘token_type_ids’])
attention_mask.append(encode_dict[‘attention_mask’])
labels.append(int(y))
#list转化成tensor格式
input_ids,token_type_ids,attention_mask = torch.tensor(input_ids),torch.tensor(token_type_ids),torch.tensor(attention_mask)
return input_ids,token_type_ids,attention_mask,labels

#1.2 dataloder批量处理
def dataLoader(input_ids,token_type_ids,attention_mask,labels):
#tensor数据整合
labels = torch.tensor(labels)
data = TensorDataset(input_ids,token_type_ids,attention_mask,labels)
loader = DataLoader(data,batch_size=BATCH_SIZE,shuffle=True) #shuffle打乱每行数据的顺序
return loader
#1.3实例化函数
#训练集带label
input_ids_train,token_type_ids_train,attention_mask_train,labels_train = dataSet(‘data/train.txt’)
train_loader = dataLoader(input_ids_train,token_type_ids_train,attention_mask_train,labels_train)
#验证集带label
input_ids_dev,token_type_ids_dev,attention_mask_dev,labels_dev = dataSet(‘data/dev.txt’)
dev_loader = dataLoader(input_ids_dev,token_type_ids_dev,attention_mask_dev,labels_dev)
#测试集
input_ids_test,token_type_ids_test,attention_mask_test,labels_test = dataSet(‘data/test.txt’)
test_loader = dataLoader(input_ids_test,token_type_ids_test,attention_mask_test,labels_test)
#得到后续用的数据为train_loader,dev_loader,test_loader

2.定义bert模型
class Bert_Model(nn.Module):
def __init__(self,bert_path,classes=10):
super(Bert_Model,self).__init__()
self.config = BertConfig.from_pretrained(bert_path)
self.bert = BertModel.from_pretrained(bert_path)
for param in self.bert.parameters():
param.requires_grad=True
self.fc = nn.Linear(self.config.hidden_size,classes) #直接分类
def forward(self,input_ids,token_type_ids,attention_mask):
output = self.bert(input_ids,token_type_ids,attention_mask)[1] #池化后的输出,是向量
logit = self.fc(output) #全连接层,概率矩阵
return logit

#实例化bert模型
model = Bert_Model(bert_path).to(DEVICE)

3.定义优化器和线性学习率
优化器
optimizer = AdamW(model.parameters(),lr=2e-5,weight_decay=1e-4) #使用Adam优化器
#设置学习率
schedule = get_cosine_schedule_with_warmup(optimizer,num_warmup_steps=len(train_loader),num_training_steps=EPOCHS*len(test_loader))

4.定义训练函数和验证测试函数
#在验证集上评估模型性能的函数
def evaluate(model,data_loader,device):
model.eval() #防止模型训练改变权值
val_true,val_pred = [],[]
with torch.no_grad(): #计算的结构在计算图中,可以进行梯度反转等操作
for idx,(ids,tpe,att,y) in enumerate(data_loader): #得到的y要转换一下数据格式
y_pred = model(ids.to(device),tpe.to(device),att.to(device)) #此时得到的是概率矩阵
y_pred = torch.argmax(y_pred,dim=1).detach().cpu().numpy().tolist() #将概率矩阵转换成标签并变成list类型
val_pred.extend(y_pred) #将标签值放入列表
val_true.extend(y.squeeze().cpu().numpy().tolist()) #将真实标签转换成list放在列表中

return accuracy_score(val_true,val_pred)
#如果是比赛没有labels_test,那么这个函数for里面没有y,输出没有test_true,处理数据的时候没有labels_test放到dataloader里
def predict(model,data_loader,device):
model.eval()
test_pred,test_true = [],[]
with torch.no_grad():
for idx,(ids,tpe,att,y) in enumerate(data_loader):
y_pred = model(ids.to(device),tpe.to(device),att.to(device)) #得到概率矩阵
y_pred = torch.argmax(y_pred,dim=1).detach().cpu().numpy().tolist() #将概率矩阵转化成标签值
test_pred.extend(y_pred)
test_true.extend(y.squeeze().cpu().numpy().tolist())
return test_pred,test_true
#训练函数
def train_and_eval(model,train_loader,valid_loader,optimizer,schedule,device,epoch):
best_acc = 0.0
patience = 0
criterion = nn.CrossEntropyLoss() #损失函数
for i in range(epoch):
start = time.time()
model.train() #开始训练
print(“***************Running training epoch{}************”.format(i+1))
train_loss_sum = 0.0
for idx,(ids,tpe,att,y) in enumerate(train_loader):
ids,tpe,att,y = ids.to(device),tpe.to(device),att.to(device),y.to(device)
y_pred = model(ids,tpe,att) #加载模型获得概率矩阵
loss = criterion(y_pred,y) #计算损失
optimizer.zero_grad() #梯度清零
loss.backward() #反向传播
optimizer.step() #更新优化参数
schedule.step() #更新学习率
train_loss_sum += loss.item()
#只打印五次结果
if(idx+1)%(len(train_loader)//5)==0:
print(“Epoch {:04d} | Step {:04d}/{:04d} | Loss {:.4f} | Time {:.4f}”.format(
i+1,idx+1,len(train_loader),train_loss_sum/(idx+1),time.time()-start))
#每一次epoch输出一个准确率
model.eval()
acc = evaluate(model,valid_loader,device) #验证模型的性能
if acc > best_acc :
best_acc = acc
torch.save(model.state_dict(),”best_bert_model.pth”) #保存*好的模型
print(“current acc is {:.4f},best acc is {:.4f}”.format(acc,best_acc))
print(“time costed = {}s \n”.format(round(time.time()-start,5)))

5.开始训练
train_and_eval(model,train_loader,dev_loader,optimizer,schedule,DEVICE,EPOCHS)
1
结果

6.加载*优模型进行测试
model.load_state_dict(torch.load(“best_bert_model.pth”))
#得到预测标签和真实标签
test_pred,test_true= predict(model,test_loader,DEVICE)
#输出测试机的准确率
print(“\n Test Accuracy = {} \n “.format(accuracy_score(test_true,test_pred)))
#打印各项验证指标
print(classification_report(test_true,test_pred,digits=4))
print(test_pred[:10])
print(‘——————‘)
print(test_true[:10])

结果

完整代码Github链接
https://github.com/young-yhx/bert_classify
我的数据在git的链接中data/
bert与LSTM的融合代码也在我的GitHub中

循环结构

循环结构

1.编写程序,计算1×2×3×…×10.

s = 1
for i in range(1,11):
s = s * i
print(“s=”,s)

#输出结果:

s= 3628800

2.编写程序,计算1+3+5+…+99.

sum = 0
for i in range(1,100,2):
sum = sum + i
print(“sum=”,sum)

#输出结果:

sum= 2500

3.编写程序,输出1~100之间所有能被3整除,但是不能被5整除的数。

for i in range(1,100):
if i%3!=0 or i%5==0:
continue
print(i,end=” “)

#输出结果:

3 6 9 12 18 21 24 27 33 36 39 42 48 51 54 57 63 66 69 72 78 81 84 87 93 96 99

4.编写程序,输出1000~2000年之间所有闰年,要求每行输出5个年份。

k=0
for i in range(1000,2000+1):
if (i%4==0 and i%100!=0) or (i%400==0):
k+=1
print(“{}”.format(i),end=” “)
if k%5==0:
print(“”)

#输出结果:

1004 1008 1012 1016 1020
1024 1028 1032 1036 1040
1044 1048 1052 1056 1060
1064 1068 1072 1076 1080
1084 1088 1092 1096 1104
1108 1112 1116 1120 1124
1128 1132 1136 1140 1144
1148 1152 1156 1160 1164
1168 1172 1176 1180 1184
1188 1192 1196 1200 1204
1208 1212 1216 1220 1224
1228 1232 1236 1240 1244
1248 1252 1256 1260 1264
1268 1272 1276 1280 1284
1288 1292 1296 1304 1308
1312 1316 1320 1324 1328
1332 1336 1340 1344 1348
1352 1356 1360 1364 1368
1372 1376 1380 1384 1388
1392 1396 1404 1408 1412
1416 1420 1424 1428 1432
1436 1440 1444 1448 1452
1456 1460 1464 1468 1472
1476 1480 1484 1488 1492
1496 1504 1508 1512 1516
1520 1524 1528 1532 1536
1540 1544 1548 1552 1556
1560 1564 1568 1572 1576
1580 1584 1588 1592 1596
1600 1604 1608 1612 1616
1620 1624 1628 1632 1636
1640 1644 1648 1652 1656
1660 1664 1668 1672 1676
1680 1684 1688 1692 1696
1704 1708 1712 1716 1720
1724 1728 1732 1736 1740
1744 1748 1752 1756 1760
1764 1768 1772 1776 1780
1784 1788 1792 1796 1804
1808 1812 1816 1820 1824
1828 1832 1836 1840 1844
1848 1852 1856 1860 1864
1868 1872 1876 1880 1884
1888 1892 1896 1904 1908
1912 1916 1920 1924 1928
1932 1936 1940 1944 1948
1952 1956 1960 1964 1968
1972 1976 1980 1984 1988
1992 1996 2000

5.编写程序,输出斐波那契数列的前20项,要求每行输出5项。

Fib1=1
Fib2=1
print(Fib1,Fib2,end=” “)
n=2
for i in range(3,20+1):
Fibi=Fib1+Fib2
Fib1=Fib2
Fib2=Fibi
n+=1
print(“{}”.format(Fibi),end=” “)
if n%5==0:
print(“”)

#输出结果:

1 1 2 3 5
8 13 21 34 55
89 144 233 377 610
987 1597 2584 4181 6765

6.编写程序,从键盘上输入10个整数,输出这10个数中所有奇数之和,偶数之和及所有数的平均值。

sum1=sum2=0
for i in range(10):
num=eval(input(“请输入一个整数:”))
if num%2==1:
sum1=sum1+num
else:
sum2=sum2+num
avg=(sum1+sum2)/10
print(“所有奇数之和:{},所有偶数之和:{},平均值:{}”.format(sum1,sum2,avg))

#输出样例:

请输入一个整数:4
请输入一个整数:23
请输入一个整数:8
请输入一个整数:9
请输入一个整数:16
请输入一个整数:25
请输入一个整数:32
请输入一个整数:17
请输入一个整数:18
请输入一个整数:17
所有奇数之和:91,所有偶数之和:78,平均值:16.9

7.编写程序,从键盘上输入若干个整数,求出这些整数中所有奇数之和、偶数之和及所有数的平均值,当从键盘输入字符”A”时,程序输出计算结果。

sum1=sum2=k=0
num=input(“请输入一个整数(输入字符A时结束处理):”)
while num!=’A’:
k=k+1
num=int(num)
if num%2==1:
sum1=sum1+num
else:
sum2=sum2+num
num=input(“请输入一个整数(输入字符A时结束处理):”)
avg=(sum1+sum2)/k
print(“所有奇数之和:{},所有偶数之和:{},平均值:{}”.format(sum1,sum2,avg))

#输出样例:

请输入一个整数(输入字符A时结束处理):5
请输入一个整数(输入字符A时结束处理):7
请输入一个整数(输入字符A时结束处理):8
请输入一个整数(输入字符A时结束处理):20
请输入一个整数(输入字符A时结束处理):A
所有奇数之和:12,所有偶数之和:28,平均值:10.0

8.编写程序,输出1×2×3+3×4×5+5×6×7+…+99×100×101的值。

sum=0
for i in range(1,100,2):
sum+=i*(i+1)*(i+2)
print(“结果为:”,sum)

#输出结果:

结果为: 13002450

9.编写程序,计算s=a+aa+aaa+…+aaa…aaa的值,其中a是1~9之间的某个数字,n是一个正整数。
例如,当a=2,n=5时,s=2+22+222+2222+22222=24690.

a=eval(input(“请输入a的值:”))
n=eval(input(“请输入n的值:”))
s=0
item=0
for i in range(1,n+1):
item=item*10+a
s=s+item
print(“值为:”,s)

#输出样例:

请输入a的值:3
请输入n的值:6
值为: 370368

10.编写程序,实现猜数游戏。在程序中随机生成一个0~9之间(包含0和9)的随机整数T,让用户通过键盘输入所猜的数。如果输入的数大于T,显示“遗憾,太大了”;如果小于T,显示“遗憾,太小了”;如此循环,直至猜中该数,显示“预测N次,你猜中了”,其中N是指用户在这次游戏中猜中该随机数一共尝试的次数。

import random
rnd=random.randint(0,9)
print(“系统刚随机产生了一个0~9之间的一个整数”)
user=int(input(“请输入你猜的数”))
k=0
while 1:
k=k+1
if user>rnd:
print(“遗憾,太大了”)
user=int(input(“请继续输入你猜的数”))
elif user<rnd:
print(“遗憾,太小了”)
user=int(input(“请继续输入你猜的数”))
else:
print(“预测{}次,你猜中了”.format(k))
break

#输出样例:

系统刚随机产生了一个0~9之间的一个整数
请输入你猜的数9
遗憾,太大了
请继续输入你猜的数5
遗憾,太小了
请继续输入你猜的数8
遗憾,太大了
请继续输入你猜的数7
预测4次,你猜中了

11.编写程序,产生两个0~100之间(包含0和100)的随机整数RND1和RND2,求这两个整数的*大公约数和*小公倍数。

import math
import random
RND1=random.randint(0,100)
RND2=random.randint(0,100)
gys=math.gcd(RND1,RND2)
gbs=RND1*RND2/gys
print(“{}和{}的*大公约数为:{},*小公倍数为:{}”.format(RND1,RND2,gys,gbs))

#输出样例:

59和43的*大公约数为:1,*小公倍数为:2537.0

12.编写程序模拟硬币的投掷。假设0表示硬币反面,1表示硬币正面。在程序中让计算机产生若干次(建议大于100次)随机数,统计0和1分别出现的次数,并观察0和1出现的次数是否相同。

import random
num0=0
n=eval(input(“请输入你要模拟投掷硬币的次数:”))
for i in range(n):
rnd=random.randint(0,1)
if rnd==0:
num0=num0+1
num1=n-num0
print(“硬币反面{}次,硬币正面面{}次”.format(num0,num1))

#输出样例:

请输入你要模拟投掷硬币的次数:6
硬币反面4次,硬币正面面2次

13.编写程序,计算“天天向上”和“天天向下”两种情况下的武力值。假设一年有365天,郭大侠*天的武力值为1.如果郭大侠每天勤于练功,每天武力值相比前一天会增加1%;如果郭大侠每天不练功,每天武力值相比前一天会减少1%。郭大侠制定了一年的练功计划:从*天开始,前五天每天练功,然后休息两天;接下来又练功五天,休息两天;如此往复,请计算一年后,郭大侠的*终武力值(结果保留2位小数)。

gdxwlz=1
for i in range(1,366):
if i%6==0 or i%7==0:
gdxwlz=gdxwlz*(1-0.01)
else:
gdxwlz=gdxwlz*(1+0.01)
print(“郭大侠的*终武力值为:{:.2f}”.format(gdxwlz))

#输出结果:

郭大侠的*终武力值为:4.72

14.编写程序,计算糖果总数。假设有一盒糖果,按照如下方式从中取糖果:
一个一个地取,正好取完
两个两个地取,还剩一个
三个三个地取,正好取完
四个四个地取,还剩一个
五个五个地取,还差一个
六个六个地取,还剩三个
七个七个地取,正好取完
八个八个地取,还剩一个
九个九个地取,正好取完
请问:这个盒子里至少有多少个糖果?

n=1
while 1:
if n%2==1 and n%3==0 and n%4==1 and n%5==4 and n%6==3 and n%7==0 and n%8==1 and n%9==0:
print(“这个盒子里一共有{}个糖果”.format(n))
break
else:
n=n+1

#输出结果:

这个盒子里一共有1449个糖果

.两数之和

1.两数之和

汤 神 2021-04-14 20:43:32 25 收藏
分类专栏: leetcode 文章标签: leetcode 算法 python 列表
版权
给定一个整数数组 nums 和一个整数目标值 target,请你在该数组中找出 和为目标值 的那 两个 整数,并返回它们的数组下标。

你可以假设每种输入只会对应一个答案。但是,数组中同一个元素在答案里不能重复出现。

你可以按任意顺序返回答案。

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/two-sum

示例 1:

输入:nums = [2,7,11,15], target = 9
输出:[0,1]
解释:因为 nums[0] + nums[1] == 9 ,返回 [0, 1] 。

示例 2:

输入:nums = [3,2,4], target = 6
输出:[1,2]

示例 3:

输入:nums = [3,3], target = 6
输出:[0,1]

方式一:循环嵌套,暴力求解!
思路分析:通过双层循环,判断num1+num2=target 并且两者索引不相等

def twoSum(nums: List[int], target: int):
for i,num1 in enumerate(nums):
for j,num2 in enumerate(nums):
if num1 + num2 == target and i != j:
return i,j

方式二:通过字典来查询
创建字典dict1

用枚举(enumerate())或者range()的方式遍历列表,dict1[index] = num

判断target-nums[index] 在nums中是否存在并且num2的下标不等于当前元素的索引

def two_sum(nums,target):
dict1 = {}
for index,num in enumerate(nums):
dict1[index] = num
num2 = target – dict1[index]
if num2 in nums and nums.index(num2) != index:
return index,nums.index(num2)

iOS获取手机上app信息

在代码中插入一段查询网址即可获取app信息以及版本信息。
查询命令:http://itunes.apple.com/lookup?id=xxxxxxxxx(9位appid数字)

获取设备上所有app (为LSApplicationProxy 对象)

  1. Class LSApplicationWorkspace_class = objc_getClass(“LSApplicationWorkspace”);
  2. NSObject *workspace = [LSApplicationWorkspace_class performSelector:@selector(defaultWorkspace)];
  3. NSArray *apps = [workspace performSelector:@selector(allInstalledApplications)];
  4. NSLog(@”apps: %@”, apps);

 

获取版本信息

  [apps[0] performSelector:NSSelectorFromString(@"shortVersionString")]

 

其他

1 /* Generated by RuntimeBrowser
2    Image: /System/Library/Frameworks/MobileCoreServices.framework/MobileCoreServices
3  */
4
5 @interface LSApplicationProxy : LSBundleProxy <NSSecureCoding> {
6     NSNumber *_ODRDiskUsage;
7     NSArray *_UIBackgroundModes;
8     NSArray *_*Plugins;
9     NSArray *_appTags;
10     NSString *_applicationDSID;
11     NSString *_applicationVariant;
12     NSArray *_audioComponents;
13     NSString *_companionAppIdentifier;
14     NSArray *_deviceFamily;
15     NSUUID *_deviceIdentifierForVendor;
16     NSArray *_directionsModes;
17     NSNumber *_downloaderDSID;
18     NSNumber *_dynamicDiskUsage;
19     NSArray *_externalAccessoryProtocols;
20     NSNumber *_familyID;
21     unsigned int _flags;
22     NSDictionary *_groupContainers;
23     NSArray *_groupIdentifiers;
24     unsigned int _installType;
25     NSNumber *_itemID;
26     NSString *_itemName;
27     NSString *_minimumSystemVersion;
28     long _modTime;
29     unsigned int _originalInstallType;
30     NSArray *_plugInKitPlugins;
31     NSArray *_pluginUUIDs;
32     NSArray *_privateDocumentIconNames;
33     LSApplicationProxy *_privateDocumentTypeOwner;
34     NSNumber *_purchaserDSID;
35     long _regTime;
36     NSDate *_registeredDate;
37     NSArray *_requiredDeviceCapabilities;
38     NSString *_sdkVersion;
39     NSString *_shortVersionString;
40     NSString *_sourceAppIdentifier;
41     NSNumber *_staticDiskUsage;
42     NSString *_storeCohortMetadata;
43     NSNumber *_storeFront;
44     NSString *_teamID;
45     NSString *_vendorName;
46     NSNumber *_versionID;
47 }
48
49 @property (nonatomic, readonly) NSNumber *ODRDiskUsage;
50 @property (nonatomic, readonly) NSArray *UIBackgroundModes;
51 @property (nonatomic, readonly) NSArray **Plugins;
52 @property (nonatomic, readonly) NSArray *appTags;
53 @property (nonatomic, readonly) NSString *applicationDSID;
54 @property (nonatomic, readonly) NSString *applicationIdentifier;
55 @property (nonatomic, readonly) NSString *applicationType;
56 @property (nonatomic, readonly) NSString *applicationVariant;
57 @property (nonatomic, readonly) NSArray *audioComponents;
58 @property (nonatomic, readonly) NSNumber *betaExternalVersionIdentifier;
59 @property (nonatomic, readonly) NSString *companionApplicationIdentifier;
60 @property (nonatomic, readonly) NSArray *deviceFamily;
61 @property (nonatomic, readonly) NSUUID *deviceIdentifierForVendor;
62 @property (nonatomic, readonly) NSArray *directionsModes;
63 @property (nonatomic, readonly) NSNumber *downloaderDSID;
64 @property (nonatomic, readonly) NSNumber *dynamicDiskUsage;
65 @property (nonatomic, readonly) NSArray *externalAccessoryProtocols;
66 @property (nonatomic, readonly) NSNumber *externalVersionIdentifier;
67 @property (nonatomic, readonly) NSNumber *familyID;
68 @property (nonatomic, readonly) BOOL fileSharingEnabled;
69 @property (nonatomic, readonly) NSDictionary *groupContainers;
70 @property (nonatomic, readonly) NSArray *groupIdentifiers;
71 @property (nonatomic, readonly) BOOL hasMIDBasedSINF;
72 @property (nonatomic, readonly) BOOL hasSettingsBundle;
73 @property (nonatomic, readonly) BOOL iconIsPrerendered;
74 @property (nonatomic, readonly) NSProgress *installProgress;
75 @property (nonatomic, readonly) unsigned int installType;
76 @property (nonatomic, readonly) BOOL isAdHocCodeSigned;
77 @property (nonatomic, readonly) BOOL isAppUpdate;
78 @property (nonatomic, readonly) BOOL isBetaApp;
79 @property (nonatomic, readonly) BOOL isInstalled;
80 @property (nonatomic, readonly) BOOL isNewsstandApp;
81 @property (nonatomic, readonly) BOOL isPlaceholder;
82 @property (nonatomic, readonly) BOOL isPurchasedReDownload;
83 @property (nonatomic, readonly) BOOL isRestricted;
84 @property (nonatomic, readonly) BOOL isWatchKitApp;
85 @property (nonatomic, readonly) NSNumber *itemID;
86 @property (nonatomic, readonly) NSString *itemName;
87 @property (nonatomic, readonly) NSString *minimumSystemVersion;
88 @property (nonatomic, readonly) BOOL missingRequiredSINF;
89 @property (nonatomic, readonly) unsigned int originalInstallType;
90 @property (nonatomic, readonly) NSArray *plugInKitPlugins;
91 @property (nonatomic, readonly) NSString *preferredArchitecture;
92 @property (nonatomic, readonly) BOOL profileValidated;
93 @property (nonatomic, readonly) NSNumber *purchaserDSID;
94 @property (nonatomic, readonly) NSDate *registeredDate;
95 @property (getter=isRemoveableSystemApp, nonatomic, readonly) BOOL removeableSystemApp;
96 @property (getter=isRemovedSystemApp, nonatomic, readonly) BOOL removedSystemApp;
97 @property (nonatomic, readonly) NSArray *requiredDeviceCapabilities;
98 @property (nonatomic, readonly) NSString *roleIdentifier;
99 @property (nonatomic, readonly) NSString *sdkVersion;
100 @property (nonatomic, readonly) NSString *shortVersionString;
101 @property (nonatomic, readonly) NSString *sourceAppIdentifier;
102 @property (nonatomic, readonly) NSNumber *staticDiskUsage;
103 @property (nonatomic, readonly) NSString *storeCohortMetadata;
104 @property (nonatomic, readonly) NSNumber *storeFront;
105 @property (nonatomic, readonly) BOOL supportsAudiobooks;
106 @property (nonatomic, readonly) BOOL supportsExternallyPlayableContent;
107 @property (nonatomic, readonly) BOOL supportsOpenInPlace;
108 @property (nonatomic, readonly) BOOL supportsPurgeableLocalStorage;
109 @property (nonatomic, readonly) NSString *teamID;
110 @property (nonatomic, readonly) NSString *vendorName;
111 @property (getter=isWhitelisted, nonatomic, readonly) BOOL whitelisted;
112
113 // Image: /System/Library/Frameworks/MobileCoreServices.framework/MobileCoreServices
114
115 + (id)applicationProxyForBundleURL:(id)arg1;
116 + (id)applicationProxyForCompanionIdentifier:(id)arg1;
117 + (id)applicationProxyForIdentifier:(id)arg1;
118 + (id)applicationProxyForIdentifier:(id)arg1 placeholder:(BOOL)arg2;
119 + (id)applicationProxyForIdentifier:(id)arg1 roleIdentifier:(id)arg2;
120 + (id)applicationProxyForItemID:(id)arg1;
121 + (id)applicationProxyWithBundleUnitID:(unsigned long)arg1;
122 + (BOOL)supportsSecureCoding;
123
124 – (id)ODRDiskUsage;
125 – (id)UIBackgroundModes;
126 – (id)*Plugins;
127 – (id)_initWithBundleUnit:(unsigned long)arg1 applicationIdentifier:(id)arg2;
128 – (id)appStoreReceiptURL;
129 – (id)appTags;
130 – (id)applicationDSID;
131 – (id)applicationIdentifier;
132 – (id)applicationType;
133 – (id)applicationVariant;
134 – (id)audioComponents;
135 – (id)betaExternalVersionIdentifier;
136 – (long)bundleModTime;
137 – (id)companionApplicationIdentifier;
138 – (void)dealloc;
139 – (id)description;
140 – (id)deviceFamily;
141 – (id)deviceIdentifierForVendor;
142 – (id)directionsModes;
143 – (id)downloaderDSID;
144 – (id)dynamicDiskUsage;
145 – (void)encodeWithCoder:(id)arg1;
146 – (id)externalAccessoryProtocols;
147 – (id)externalVersionIdentifier;
148 – (id)familyID;
149 – (BOOL)fileSharingEnabled;
150 – (id)groupContainers;
151 – (id)groupIdentifiers;
152 – (BOOL)hasMIDBasedSINF;
153 – (BOOL)hasSettingsBundle;
154 – (unsigned int)hash;
155 – (id)iconDataForVariant:(int)arg1;
156 – (BOOL)iconIsPrerendered;
157 – (id)iconStyleDomain;
158 – (id)initWithCoder:(id)arg1;
159 – (id)installProgress;
160 – (id)installProgressSync;
161 – (unsigned int)installType;
162 – (BOOL)isAdHocCodeSigned;
163 – (BOOL)isAppUpdate;
164 – (BOOL)isBetaApp;
165 – (BOOL)isEqual:(id)arg1;
166 – (BOOL)isInstalled;
167 – (BOOL)isNewsstandApp;
168 – (BOOL)isPlaceholder;
169 – (BOOL)isPurchasedReDownload;
170 – (BOOL)isRemoveableSystemApp;
171 – (BOOL)isRemovedSystemApp;
172 – (BOOL)isRestricted;
173 – (BOOL)isSystemOrInternalApp;
174 – (BOOL)isWatchKitApp;
175 – (BOOL)isWhitelisted;
176 – (id)itemID;
177 – (id)itemName;
178 – (id)localizedName;
179 – (id)localizedNameForContext:(id)arg1;
180 – (id)localizedShortName;
181 – (id)machOUUIDs;
182 – (id)minimumSystemVersion;
183 – (BOOL)missingRequiredSINF;
184 – (unsigned int)originalInstallType;
185 – (id)plugInKitPlugins;
186 – (void)populateNotificationData;
187 – (id)preferredArchitecture;
188 – (BOOL)privateDocumentIconAllowOverride;
189 – (id)privateDocumentIconNames;
190 – (id)privateDocumentTypeOwner;
191 – (id)privateIconsDictionary;
192 – (BOOL)profileValidated;
193 – (id)purchaserDSID;
194 – (id)registeredDate;
195 – (id)requiredDeviceCapabilities;
196 – (id)resourcesDirectoryURL;
197 – (id)roleIdentifier;
198 – (id)sdkVersion;
199 – (void)setPrivateDocumentIconAllowOverride:(BOOL)arg1;
200 – (void)setPrivateDocumentIconNames:(id)arg1;
201 – (void)setPrivateDocumentTypeOwner:(id)arg1;
202 – (id)shortVersionString;
203 – (id)sourceAppIdentifier;
204 – (id)staticDiskUsage;
205 – (id)storeCohortMetadata;
206 – (id)storeFront;
207 – (BOOL)supportsAudiobooks;
208 – (BOOL)supportsExternallyPlayableContent;
209 – (BOOL)supportsOpenInPlace;
210 – (BOOL)supportsPurgeableLocalStorage;
211 – (id)teamID;
212 – (id)uniqueIdentifier;
213 – (id)userActivityStringForAdvertisementData:(id)arg1;
214 – (id)vendorName;
215 – (id)versionIdentifier;
216
217 // Image: /System/Library/Frameworks/UIKit.framework/UIKit
218
219 – (struct CGSize { float x1; float x2; })_defaultStyleSize:(id)arg1;
220 – (struct { int x1; struct CGSize { float x_2_1_1; float x_2_1_2; } x2; }*)_iconVariantDefinitions:(id)arg1;
221
222 // Image: /System/Library/PrivateFrameworks/UserNotification.framework/UserNotification
223
224 + (id)un_bundleForBundleIdentifier:(id)arg1;
225
226 – (id)_un_bundle;
227 – (BOOL)_un_isReallyInstalled;
228 – (BOOL)_un_isResourceValidForPath:(id)arg1 withContainerPath:(id)arg2;
229 – (BOOL)_un_usesLocalNotification;
230 – (id)un_infoDictionary;
231 – (BOOL)un_isSystemApplication;
232 – (id)un_pathForSoundName:(id)arg1;
233 – (BOOL)un_requiresLocalNotification;
234 – (BOOL)un_shouldUseDefaultDataProvider;
235
236 @end
友情链接: SITEMAP | 旋风加速器官网 | 旋风软件中心 | textarea | 黑洞加速器 | jiaohess | 老王加速器 | 烧饼哥加速器 | 小蓝鸟 | tiktok加速器 | 旋风加速度器 | 旋风加速 | quickq加速器 | 飞驰加速器 | 飞鸟加速器 | 狗急加速器 | hammer加速器 | trafficace | 原子加速器 | 葫芦加速器 | 麦旋风 | 油管加速器 | anycastly | INS加速器 | INS加速器免费版 | 免费vqn加速外网 | 旋风加速器 | 快橙加速器 | 啊哈加速器 | 迷雾通 | 优途加速器 | 海外播 | 坚果加速器 | 海外vqn加速 | 蘑菇加速器 | 毛豆加速器 | 接码平台 | 接码S | 西柚加速器 | 快柠檬加速器 | 黑洞加速 | falemon | 快橙加速器 | anycast加速器 | ibaidu | moneytreeblog | 坚果加速器 | 派币加速器 | 飞鸟加速器 | 毛豆APP | PIKPAK | 安卓vqn免费 | 一元机场加速器 | 一元机场 | 老王加速器 | 黑洞加速器 | 白石山 | 小牛加速器 | 黑洞加速 | 迷雾通官网 | 迷雾通 | 迷雾通加速器 | 十大免费加速神器 | 猎豹加速器 | 蚂蚁加速器 | 坚果加速器 | 黑洞加速 | 银河加速器 | 猎豹加速器 | 海鸥加速器 | 芒果加速器 | 小牛加速器 | 极光加速器 | 黑洞加速 | movabletype中文网 | 猎豹加速器官网 | 烧饼哥加速器官网 | 旋风加速器度器 | 哔咔漫画 | PicACG | 雷霆加速