Python语言程序设计我爱编程

练习3: 基本数据类型 (第3周)

2018-04-15  本文已影响1001人  努力奋斗的durian

文章原创,最近更新:2018-04-15

1.平方值格式化
2.同符号数学运算
3.天天向上的力量 III
4.星号三角形 I
5.恺撒密码 I
原链接 Python123语言程序设计北京理工大学

1.平方值格式化

描述
获得用户输入的一个整数N,计算N的平方值;结果采用宽度20字符方式居中输出,空余字符采用减号(-)填充。
如果结果超过20个字符,则以结果宽度为准。



代码如下:

a=eval(input(""))
b=pow(a,2)
print(str(b).center(20,"-"))

输出结果如下:


2.同符号数学运算

描述
读入一个整数N,分别计算如下内容:

  1. N的绝对值;
  2. N与10进行同符号加法、减法和乘法运算,同符号运算指使用N的绝对值与另一个数进行运算,运算结果的绝对值被赋予N相同的符号,其中,0的符号是正号。
    将上述4项结果在一行输出,采用空格分隔,输出结果均为整数。

输入
示例1:100


输出
示例1:100 110 90 1000


代码如下:

N=eval(input(""))
a=abs(N)
if N>=0:
    b=abs(a+10)
    c=abs(a-10)
    d=abs(a*10)
else:
    b=-abs(a+10)
    c=-abs(a-10)
    d=-abs(a*10)    
print(a,b,c,d)

输出结果为:


3.天天向上的力量 III

描述
一年365天,以第1天的能力值为基数,记为1.0。

当好好学习时,能力值相比前一天提高N‰;当没有学习时,能力值相比前一天下降N‰。

每天努力或放任,一年下来的能力值相差多少呢?其中,N的取值范围是0到100,N可以是小数,假设输入符合要求。

获得用户输入的N,计算每天努力和每天放任365天后的能力值及能力间比值,其中,能力值保留小数点后2位,能力间比值输出整数,输出结果间采用英文逗号分隔。

使用input()获得N。


输入
示例1:

1


输出
示例1:

1.44,0.69,2


代码如下:

N=eval(input(""))
dayup=pow((1.0+0.001*N),365)
a="{:.2f}".format(dayup)
daydown=pow((1.0-0.001*N),365)
b="{:.2f}".format(daydown)
c=int(dayup/daydown)
print(a+","+b+","+str(c))

输出结果如下:


4.星号三角形 I

描述
读入一个整数N,N是奇数,输出由星号字符组成的等边三角形,要求:

第1行1个星号,第2行3个星号,第3行5个星号,依次类推,最后一行共N的星号。


输入
示例1:3


代码如下:

N=eval(input(""))
if N%2 in [1]:
    i=1
    while (2*i-3)< N:
        t="*"* (2*i-1)
        i=i+1
        print(t.center(N," "))

else:
    print()

输出结果如下:


5.恺撒密码 I

描述
凯撒密码是古罗马凯撒大帝用来对军事情报进行加解密的算法,它采用了替换方法对信息中的每一个英文字符循环替换为字母表序列中该字符后面的第三个字符,即,字母表的对应关系如下:

原文:A B C D E F G H I J K L M N O P Q R S T U V W X Y Z

密文:D E F G H I J K L M N O P Q R S T U V W X Y Z A B C

对于原文字符P,其密文字符C满足如下条件:C=(P+3) mod 26

上述是凯撒密码的加密方法,解密方法反之,即:P=(C-3) mod 26

假设用户可能使用的输入仅包含小写字母a~z和空格,请编写一个程序,对输入字符串进行凯撒密码加密,直接输出结果,其中空格不用进行加密处理。使用input()获得输入。


输入
示例1: python is good


输出
示例1: sbwkrq lv jrrg


代码如下:

c = input("")
for i in c:
    if ord(i) in range(97,124):
        x=97+(ord(i)+3-97)%26
        y=chr(x)
        print(y,end="")
    else:
        print(" ",end="")

输出结果为:


这道题的描述公式我看得不是很懂,自己重新推理了一遍.
a的ASCII 码为97,小写字母转换成ASCII 码是由ord()函数转换,比如ord(a),显示的结果为97
a~z,共26个字母,以等差为1的递增序列的函数,故a~z的ASCII 码为97~122.
假设加密后字符为C(i)函数:比如a的ASCII 码为97 ,经过加密后,变为d的ASCII 码为 100
C(a)=97+(ord(a)+3-97)%26=100(a→d,a加密后变成d)
C(b)=97+(ord(b)+3-97)%26=101(b→e,b加密后变成e)
C(x)=97+(ord(x)+3-97)%26=97(x→a,x加密后变成a)
.....................................................
由此推出C(i)=97+(ord(i)+3-97)%26

上一篇 下一篇

猜你喜欢

热点阅读