python-情报加密副本

【问题描述】某情报机构采用公用电话传递数据,数据是5位的整数,在传递过程中是加密的。加密规则如下:每位数字都加上8,然后用和除以7的余数代替该数字,再将第1位和第5位交换,第2位和第4位交换。请编写程序,完成明文至密文的加密过程。

【输入形式】输入一个5位整数

【输出形式】输出加密后的密文整数

【样例输入】12345

【样例输出】65432

++完整代码如下:++

n=int(input())

a=[]

if 10000>n or 99999<n:

print("您输如的不是五位数,请重新输入:")

else:

b=n%10

c=n//10%10

d=n//100%10

e=n//1000%10

f=n//10000

g=[b,c,d,e,f]

for i in range(len(g)):

g[0]=g[0]+8

g[0]=g[0]%7

a.append(g[0])

del g[0]

print("{}{}{}{}{}".format(a[0],a[1],a[2],a[3],a[4]))

++代码解释:++

"n=int(input())

a=[]

if 10000>n or 99999<n:

print("您输如的不是五位数,请重新输入:") ",让用户输入一个五位数,建立一个空列表,并判断用户输入的是不是五位数。

"else:

b=n%10

c=n//10%10

d=n//100%10

e=n//1000%10

f=n//10000 ",判断是五位数的情况下分别求出该五位数的个,十,百,千,万位数字。

"g=[b,c,d,e,f]",将分别求出的该五位数的个,十,百,千,万位数字按个,十,百,千,万的顺序存入列表g中。

"for i in range(len(g)):

g[0]=g[0]+8

g[0]=g[0]%7

a.append(g[0])

del g[0] ",按照加密规则:利用循环将列表g中每个数字都加上8,然后用和除以7的余数代替该数字。然后将替代该数字的余数存入列表a中,之后将列表g中替代该数字的余数删除。

"print("{}{}{}{}{}".format(a[0],a[1],a[2],a[3],a[4]))",由于列表添加的默认顺序为添加到列表的最后末尾,因此列表a中五位数字的排列顺序已经在将g列表中余数存入列表a中时掉转,此时只需要按正常顺序排列即可。

++运行效果展示:++

++++

++(声明:以上内容均为原创)++

相关推荐
阿方.91811 小时前
《数据结构全解析:栈(数组实现)》
java·开发语言·数据结构
摆烂z11 小时前
Jupyter Notebook的交互式开发环境方便py开发
ide·python·jupyter
小欣加油12 小时前
leetcode 912 排序数组(归并排序)
数据结构·c++·算法·leetcode·排序算法
一乐小哥12 小时前
一口气同步10年豆瓣记录———豆瓣书影音同步 Notion分享 🚀
后端·python
华研前沿标杆游学12 小时前
华为在国内搞的研发基地有多野?标杆游学带你解锁“研发界顶流”
python
小胖墩有点瘦13 小时前
【基于深度学习的中草药识别系统】
人工智能·python·深度学习·课程设计·计算机毕业设计·中草药识别
zl_dfq13 小时前
数据结构 之 【模拟实现哈希表】
数据结构
正在走向自律13 小时前
Ubuntu系统下Python连接国产KingbaseES数据库实现增删改查
开发语言·数据库·python·ubuntu·kingbasees·ksycopg2
Calihen的学习日志14 小时前
【Pandas】3.1-数据预处理:列的基本操作
python·pandas
打螺丝否14 小时前
稠密矩阵和稀疏矩阵的对比
python·机器学习·矩阵