python基础小白题2

题目11:判断101-200之间有多少个素数,并输出所有素数。

 

num=[]

for i in range(100,201):

    j=i//2              

    for k in range(2,j):

        if i%k==0:

            break

    else:

        num.append(i)

print('一共有%d个素数\n这些素数是:' %len(num),num )

输出结果:

一共有21个素数

这些素数是: [101, 103, 107, 109, 113, 127, 131, 137, 139, 149, 151, 157, 163, 167, 173, 179, 181, 191, 193, 197, 199]

题目12:打印出所有的“水仙花数”,所谓“水仙花数”是指一个三位数,其各位数字立方和等于该数字本身。例如:153=1的三次方+5的三次方+3的三次方。

 

num=[]

def cubic_sum(n):

    return n*n*n

for i in range(100,1000):

    i_hun=i//100                  #百位

    i_ten=(i%100)//10             #十位

    i_bit=i-i_hun*100-i_ten*10    #个位

    i_sum=cubic_sum(i_bit)+cubic_sum(i_ten)+cubic_sum(i_hun)

    if i_sum==i:

        num.append(i)

print(num)

输出结果:

[153, 370, 371, 407]

题目13:讲一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。

 

num=[]                  #该数字的所有素数

fac_num=[]              #该数字的因数

def pri_num(val):       #求出该数字的所有素数

    for i in range(2,val):

        if i<=4:

            j=i

        else:

            j=i//2              

        for k in range(2,j):

            if i%k==0:

                break

        else:

            num.append(i)

def sol_factor(val,*k):   #求因数

    for i in k:           #遍历素数

        if val%i==0:

            return i

            break

input_num=int(input('请输入要分解的数:'))

pri_num(input_num)               #求出该数字的所有素数

decom_num=input_num              #要分解的数

while True:

    res=sol_factor(decom_num,*num)

    if res==decom_num:           #遍历结束

        fac_num.append(str(res))

        break

    else:

        fac_num.append(str(res))

        decom_num= decom_num/res

print(input_num,'=','*'.join(fac_num))#分解后的表达式

输出结果:

  请输入要分解的数:180

  180 = 2*2*3*3*5

  请输入要分解的数:900

  900 = 2*2*3*3*5*5

题目14:利用条件运算符的嵌套来完成此题:学习成绩>=90分的同学用A表示,60-89分之间的用B表示,60分以下的用C表示。

 

score=int(input('请输入分数:').strip())

if score < 0  or score>100:

    print('输入的分数不合理,请重新输入')

elif score >= 90:

    print('该同学得A') 

elif score >=60 and score<90:

    print('该同学得B')

else:

    print('该同学得C')

题目15:输入一行字符,分别统计出其中英文字母、空格、数字和其它字符的个数。

 

input_str=input('请输入要统计的字符串:')

count_str={}

for i in input_str:

    if i in count_str:

        count_str[i] +=1

    else:

        count_str[i] =1

print(count_str)

输出结果:

  请输入要统计的字符串:kahgasodgh934q455t

{'o': 1, 't': 1, '4': 2, 'q': 1, 'h': 2, '5': 2, 'd': 1, '3': 1, '9': 1, 's': 1, 'a': 2, 'g': 2, 'k': 1}

题目16:求s=a+aa+aaa+aaaa+aa..a的值,其中a是一个数字。例如:2+22+222+2222+22222(此时公有五个数相加),几个数相加由键盘控制。

 

def sum_num(num,dig_num):

    var=0

    for i in range(dig_num):

        var +=int((num*(i+1)))

        if i==(dig_num-1):

            print(int((num*(i+1))),end='=')   #整数乘字符  ,'3'*3='333'

        else:

            print(int((num*(i+1))),end='+')

    return var

         

         

num=input('请输入要计算的数字:')         #字符类型

dig_num=int(input('请输入要计算的次数:'))#整数类型

sum_dig=sum_num(num,dig_num)

print(sum_dig)

输出结果:

  请输入要计算的数字:1

  请输入要计算的次数:3

  1+11+111=123

  请输入要计算的数字:2

  请输入要计算的次数:5

  2+22+222+2222+22222=24690

题目17:一个数如果恰好等于它的因子之和,这个数成为“完数”、例如6=1+2+3.编写程序找出1000以内所有的完数。

 

def pri_num(val):          #求出该数字的所有素数

    for i in range(2,val+1):

        if i<=4:

            j=i

        else:

            j=i//2              

        for k in range(2,j):

            if i%k==0:

                break

        else:

            num.append(i)

def sol_factor(val,*k):    #求因数

    for i in k:             #遍历素数

        if val%i==0:

            return i

            break

    else:

        return 1

for input_num in range(2,1000):

    sum_num=1

    num=[]                  #该数字范围内的所有素数

    fac_num=[]              #该数字的因数

    pri_num(input_num)      #求出该数字的所有素数

    decom_num=input_num     #要分解的数

    while True:

        res=sol_factor(decom_num,*num)

        if res==decom_num:           #遍历结束

            sum_num +=res

            fac_num.append(str(res))

            break

        else:

            sum_num +=res

            fac_num.append(str(res))

            decom_num= decom_num/res

    if sum_num==input_num:

        print(input_num,'=1+','+'.join(fac_num)) #分解后的表达式

输出结果:

  6 =1+ 2+3

题目18:一个球从100米高度自由下落,每次落地后跳回原高度的一半;再落地,求它在第10次落地时,共经过过少米?第10次反弹多高?

 

high=100

sum_meter=0

for i in range(10):

    if i==0:        #第一次落地

        sum_meter +=high

        high /=2

    else:

        sum_meter += (2*high)

        high /=2

#     print('第%d次落地可以反弹的高度: %f' %((i+1),high))

#     print('第%d次落地经过了%f米' %((i+1),sum_meter))

print('----------------------------------')

print('第10次落地可以反弹的高度: %f米' %(high))

print('一共经过了%f米' %(sum_meter))

输出结果:

  第1次落地可以反弹的高度: 50.000000

  第1次落地经过了100.000000米

  第2次落地可以反弹的高度: 25.000000

  第2次落地经过了200.000000米

  第3次落地可以反弹的高度: 12.500000

  第3次落地经过了250.000000米

  第4次落地可以反弹的高度: 6.250000

  第4次落地经过了275.000000米

  第5次落地可以反弹的高度: 3.125000

  第5次落地经过了287.500000米

  第6次落地可以反弹的高度: 1.562500

  第6次落地经过了293.750000米

  第7次落地可以反弹的高度: 0.781250

  第7次落地经过了296.875000米

  第8次落地可以反弹的高度: 0.390625

  第8次落地经过了298.437500米

  第9次落地可以反弹的高度: 0.195312

  第9次落地经过了299.218750米

  第10次落地可以反弹的高度: 0.097656

  第10次落地经过了299.609375米

  ----------------------------------

  第10次落地可以反弹的高度: 0.097656米

  一共经过了299.609375米

题目19:求1+2!+3!+4!+...20!的和。

 

def factorial_sum(num):

    if num==1:

        return 1

    else:

        return num*factorial_sum(num-1)

res=0

for i in range(1,21):

    res +=factorial_sum(i)

    if i ==20 :

        print(i,end='!=')

    else :

        print(i,end='!+')

print(res)   

输出结果:

  1!+2!+3!+4!+5!+6!+7!+8!+9!+10!+11!+12!+13!+14!+15!+16!+17!+18!+19!+20!=2561327494111820313

题目20:猴子第一天摘下若干个桃子,当即吃了一半,还不过瘾又多吃了一个;第二天早上又将剩下的桃子吃掉一半,又多吃了一个;以后每天早上都吃前一天剩下的一半多一个。到第十天早上想吃桃子时,只剩下了一个。求第一天共摘了多少。

 

peach_num=0   #可以整除2,一定是偶数个桃子

Flages=True

while Flages:

    peach_num +=2

    temp=peach_num

    for i in range(3):         #遍历次数,检验

        temp=temp/2

        if temp==int(temp): #当中有一次无法整除就退出

            temp -=1

            if temp==0:        #不能为0

                break

        else:

            break

    else:

        if temp==1:

            Flages = False

print('第一天摘了%d个桃子' %peach_num)

输出结果:

  假设第二天只剩一个桃子时:第一天摘了4个桃子。

  假设第三天只剩一个桃子时:第一天摘了10个桃子.

  假设第四天只剩一个桃子时:第一天摘了22个桃子.

  假设第五天只剩一个桃子时:第一天摘了46个桃子.

  ...

  假设第十天只剩一个桃子时:第一天摘了1534个桃子.

兔兔RabbitMQ!!! CSDN认证博客专家 Go/GoLang Redis MySQL
全站最硬核博主(之一)。在腾讯总部工作,bat/tmd有五家发过offer。acm/leetcode刷题狂,c /Java/python/go/php各种后端语言都喜欢,安卓/node/叶子/jsp等前端也能写,最喜欢鼓捣各种组件,请多指教。
已标记关键词 清除标记
相关推荐
<p> <span style="color:#797979;font-family:微软雅黑, 黑体, 'Microsoft YaHei', 宋体, sans-serif;font-size:13px;background-color:#ffffff;"> </span> </p> <p class="MsoNormal"> <span style="color:#337FE5;font-size:16px;"><strong><b><a target="_blank" href="https://edu.csdn.net/bundled/detail/308"></a><a target="_blank" href="https://edu.csdn.net/bundled/detail/308"><span> </span></a></b></strong></span> </p> <p class="ql-long-39788408" style="font-size:11pt;color:#494949;"> <strong><b><a class="ql-link ql-size-12 ql-author-39788408" href="https://edu.csdn.net/bundled/detail/298" target="_blank"><strong>[本课程属于AI完整学习路线套餐,该套餐已“硬核”上线,点击立即学习!]</strong></a> </b></strong> </p> <p> <br /> </p> <p class="MsoNormal"> <span style="color:#337FE5;font-size:16px;"><strong><img src="https://img-bss.csdnimg.cn/202011090217226256.png" alt="" /><br /> </strong></span> </p> <p class="MsoNormal"> <span style="color:#337FE5;font-size:16px;"><strong><br /> </strong></span> </p> <p class="MsoNormal"> <span style="color:#337FE5;font-size:16px;"><strong>[<span style="font-family:微软雅黑, 黑体, "font-size:13px;background-color:#FFFFFF;">Python</span><span style="font-family:微软雅黑, 黑体, "font-size:13px;background-color:#FFFFFF;">是目前最火的编程语言</span>]</strong></span>  </p> <p class="MsoNormal"> <span style="color:#000000;font-size:16px;">Python</span><span style="color:#000000;font-size:16px;">是目前最火的编程语言(没有之一),特别是在人工智能和深度学习领域,有关</span><span style="color:#000000;font-size:16px;">Python</span><span style="color:#000000;font-size:16px;">的课程也和雨后春笋一般大量涌现,但是这些课程大多目的性不强,</span><span style="color:#000000;font-size:16px;">过多抠语法,大而全,但是实用性不强,一段时间不用很容易就忘记了。因此本课程专为想学习</span><span style="color:#000000;font-size:16px;">/从事人工智能领域的同学设计,重点介绍人工智能中最常用的Python</span><span style="color:#000000;font-size:16px;">知识,重点讲解</span><span style="color:#000000;font-size:16px;">numpy</span><span style="color:#000000;font-size:16px;">等实用模块,同时大量结合习和实战,帮助大家快速上手</span><span style="color:#000000;font-size:16px;">Python。</span> </p> <p class="MsoNormal"> <br /> </p> <p class="MsoNormal"> <span style="color:#337FE5;font-size:16px;"><strong>【课程涵盖技术点】</strong></span> </p> <p class="MsoNormal">   </p> <p class="MsoNormal" style="text-indent:0px;"> <span style="color:#000000;font-size:16px;">1、Python开发环境的准备(Anaconda, Jupyter Notebook, Spyder)</span> </p> <p class="MsoNormal" style="text-indent:0px;"> <span style="color:#000000;font-size:16px;">2Python基础知识(变量类型,基础数学运算,基础语法,常用数据结构,比较和逻辑运算,循环语句,Python函数,文件IO,时间模块与OS模块,异常处理)</span> </p> <p class="MsoNormal" style="text-indent:0px;"> <span style="color:#000000;font-size:16px;">3、Numpy的使用(ndarray,向量与矩阵的形变和运算,向量和矩阵的生成、运算、拼接、和索引,常用numpy科学计算方法)</span> </p> <p class="MsoNormal" style="text-indent:0px;"> <span style="color:#000000;font-size:16px;">4、Pandas 和 Matplotlib</span> </p> <p class="MsoNormal" style="text-indent:0px;"> <span style="color:#000000;font-size:16px;">5、爬虫实战(</span><span style="color:#000000;font-size:16px;">Request,BeautifulSoup)</span> </p> <p class="MsoNormal" style="text-indent:0px;"> <span style="color:#000000;font-size:16px;"><br /> </span> </p> <p class="MsoNormal" style="text-indent:0px;"> <span style="color:#337FE5;font-size:16px;"><strong>【3天</strong></span><span style="font-weight:bold;color:#337FE5;font-size:16px;">时间学习最实用知识,</span><span style="font-weight:bold;color:#337FE5;font-size:16px;">快速上手实战案<span style="color:#337FE5;">例</span></span><strong><span style="color:#337FE5;">】</span></strong> </p> <p class="MsoNormal" style="text-indent:0px;">   </p> <p class="MsoNormal" style="text-indent:0px;"> <img alt="" src="https://img-bss.csdnimg.cn/202009100354198952.png" /><img alt="" src="https://img-bss.csdnimg.cn/202009100354253635.png" />  </p> <p class="MsoNormal" style="text-indent:0px;"> <br /> </p> <p class="MsoNormal" style="text-indent:0px;"> <br /> </p> <p class="MsoNormal" style="text-indent:0px;"> <strong><span style="color:#337FE5;"></span></strong> </p>
©️2020 CSDN 皮肤主题: 书香水墨 设计师:CSDN官方博客 返回首页