day5-practice

1.一张纸的厚度大约是0.08mm,对折多少次之后能达到珠穆朗玛峰的高度(8848.13米)?

规律:n=1(折一次):厚度为0.08 * 21 ;n=2:厚度为0.0822 ; n=n:厚度为0.082**n
n = 1   # 第一次循环的初始值设为1,代表折第一次
while True:
    sum1 = 0.08 * (2**n)   # 折n次的高度,比如:折一次的高度为 0.08*2**1
    if sum1>=8848130:      # 如果总的高度>8848130mm,就终止循环,否则,继续算sum1 = 0.08 * (2**n)
        break
    n += 1
print(n)

2. 古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,

小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?

num = 10 # 求第20个月有几对兔子
m1 = 1  # 第一个月有1对兔子
m2 = 1  # 第二个月有1对兔子
i = 3   # 从第三个月起,兔子有几对
for i in range(3,num+1):
    current = m1 + m2
    print('第',i,'个月','有',current,'对兔子')
    m1,m2 = m2,current
3. 将一个正整数分解质因数。例如:输入90,打印出90=2x3x3x5。
list1 = [] #创建一个空列表
num = int(input('请输入一个正整数:'))
# 判断 num 能否被2~它本身-1(i)的数整除,如果能i就是它的质因数,
# 随着循环的过程num不断减小,所以不用担心出现重复录入的情况
for i in range(2,num):
    while True:
        if num % i == 0:
            list1.append(i)
            num = num / i
        else:
            break
print(list1)


"""
循环分解:
num = 12
i = (2,3,4,5,6,7,8,9,10,11)
i = 2, 12 % 2 == 0  true  list1.append(2)  num=12/2=6
i = 2, 6 % 2 == 0   true  list1.append(2)  num=6/2=3 
i = 2, 3 % 2 != 0   false      break   
i = 3, 12 % 3 == 0  true  list1.append(3)  num=12/3=4
i = 3, 4 % 3 !=0   false      break
i = 4, 4 % 4 ==0   true  list1.append(4)  num=4/4=1
i = 4, 1 % 4 !=0   false     break
i = 5, 1 % 5 !=0   false     break
i = 6, 1 % 6 !=0   false     break
....
"""

4.输入两个正整数m和n,求其最大公约数和最小公倍数。 程序分析:利用辗除法。

最大公约数:num1 % num2 =x ;如果x==0,那么num2为最大公约数,如果x!=0,那么num1=num2,num2=x,再循环
最小公倍数:两个数之积除以最大公约数
# 前提是num1>num2
num1 = int(input('请输入一个正整数:'))
num2 = int(input('请输入另一个正整数:'))
a = num1
b = num2
if num1>num2:
    while True:
        x = num1 % num2
        if x ==0:
            break
        num1 , num2 = num2 , x
    print('最大公约数是:', num2)
    print('最小公倍数:',(a*b)/num2)

5. 一个数如果恰好等于它的因子之和,这个数就称为 "完数 "。例如6=1+2+3. 编程 找出1000以内的所有完数

for num in range(1,1000):   # 从1-1000中取出一个数
    sum = 0                 # 设定sun的初始值为0
    # 先判断取出的num值,再找出num的因子们(1~num-1的数是否能够被num整除),如果能整除sum就加上因子

    for i in range(1,num):
        if num % i ==0:
            sum += i
    # 循环完之后,如果num==sum 就说明是完数
    if sum == num:
        print(num,'是完数')

6.输入某年某月某日,判断这一天是这一年的第几天? 程序分析:以3月5日为例,应该先把前两个月的加起来, 然后再加上5天即本年的第几天,特殊情况,闰年且输入月份大于3时需考虑多加一天。

year = int(input('请输入年份:'))
month = int(input('请输入月份:'))
day = int(input('请输入号数:'))

# 第一步:判断年份是否是闰年
isleap_year = True   # 假定输入的年份是闰年
if (year % 4 ==0 and year % 100 !=0) or year % 400==0:
    isleap_year = True       # 满足条件即为闰年,假设成立,2月是29天
    months_list = [31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]
else:                      # 假设的条件不成立,2月是28天
    months_list = [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]

# 第二步:计算天数
# 如果month ==i ,就加上列表中的月份对应的天数
days_sum = 0
for i in range(1,13):
    if i == month:
        for x in range(i-1):      # 对month_list列表中输入月份的前几个月份天数相加(循环列表,循环一次加一次)
            days_sum = days_sum + months_list[x]  #从索引0开始循环
        print('这是',year,'年的第',days_sum+day,'天')

7. 某个公司采用公用电话传递数据,数据是四位的整数,在传递过程中是加密的,加密规则如下:

每位数字都加上5,然后用每个数字的和除以10的余数代替该数字,再将第一位和第四位交换,第二位和第三位交换。求输入的四位整数加密后的值
num = int(input('请输入一个四位数:'))
# 第一步:取出num的个位、十位、百位、千位
num_list=[]  # 定义一个空列表
num_list.append(num // 1000)          # 将千位上的数字添加进列表
num_list.append(num // 100  % 10)     # 将百位上的数字添加进列表
num_list.append(num % 100 // 10)      # 将十位上的数字添加进列表
num_list.append(num % 10)             # 将个位上的数字添加进列表
# num_list[个,十,百,千]

# 第二步:加密
# i 分别取列表中的值进行加5和取余(i 的值代表列表中的索引值)
for i in range(4):
    num_list[i] +=5
    num_list[i] %=10
# x分别取列表中的值进行交换
for x in range(2):
    num_list[x],num_list[3-x] = num_list[3-x],num_list[x]
print(num_list)


"""
第二个for循环分解详情:(例如:现在的列表是[6,7,8,9])

x = 0   num_list[0],num_list[3] = num_list[3],num_list[0]   # 第一位,第四位 = 第四位,第五位
x = 1   num_list[1],num_list[2] = num_list[2],num_list[1]   # 第二位,第三位 = 第三位,第二位
"""
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,457评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,837评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,696评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,183评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,057评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,105评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,520评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,211评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,482评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,574评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,353评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,213评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,576评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,897评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,174评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,489评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,683评论 2 335

推荐阅读更多精彩内容

  • 在C语言中,五种基本数据类型存储空间长度的排列顺序是: A)char B)char=int<=float C)ch...
    夏天再来阅读 3,281评论 0 2
  • 一、快捷键 ctr+b 执行ctr+/ 单行注释ctr+c ...
    o_8319阅读 5,770评论 2 16
  • 【程序1】 题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔...
    叶总韩阅读 5,116评论 0 41
  • 【程序1】 题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔...
    开心的锣鼓阅读 3,302评论 0 9
  • C语言的学习要从基础开始,这里是100个经典的算法-1C语言的学习要从基础开始,这里是100个经典的 算法 题目:...
    Poison_19ce阅读 1,108评论 0 0