python 练习题

news2024/11/18 19:37:38

for 循环 和 while 循环

  1. 判断101-200之间有多少个素数,并输出所有素数。
    (什么是素数(质数): 除了1和它本身,不能被其他的数整除)
方法1:
count = 0                       # 设定素数的初始个数为0
for num in range(101,201):      # 第一个循环:从101-200之间的数中依次取一个数,来判断它是不是素数
    # 判断取出来的数能不能被(2~本身-1)的数整除,如果能被整除,就不是素数。
    for x in range(2,num):
        if num % x == 0:
            break
        count +=1
    else:
        print(num,'是素数')
print('素数的个数:',count)     # 打印出素数总的个数
"""
如果取出来的数都不能被整除,那么就是素数
(即说明if条件语句为Flase,if中的语句块不能被执行),count就会加上1,else中的也会被执行一次
如果取出来的数能被整除,那么不是素数,会被break掉,进行取下一个数的循环,不会执行count 和else
"""


方法2:
count = 0
for num in range(101,201):
    isprime = True              # 取出一个数,就假定它是素数,然后再验证假设是否正确
    for x in range(2,num):
        if num % x ==0:         # 如果 num 能够被(2,num)中的任意个数整除,说明假设是错误的,终止
            isprime = False
            break
        count += 1
    if isprime == True:         # 循环结束之后,找出是素数的
        print(num,'是素数')
print('素数的个数:',count)
  1. 求斐波那契数列中第n个数的值:1,1,2,3,5,8,13,21,34, 55…

规律: 从第三个数开始,后面每个数结果都是前两个数的和 ;如果想知道第三位数是什么,需要知道第1、2位数什么

n = int(input('你想知道第几个数的值:'))
# 当前的数:current = s1+s2
s1 = 1
s2 = 1
i = 3     # 位数的起始值是3,假设前两位都知道了:s1,s2=1
for i in range(3,n+1):
    # 根据前两个数的值,求出当前数的值
    current = s1+s2
    # 挪一次,为下次循环求下个值
    s1,s2 = s2,current
print(current)
  1. 有一分数序列:2/1,3/2,5/3,8/5,13/8,21/13…求出这个数列列的第20个分数
    规律:后面的分数的分母 == 前一个分数的分子 后面的分数的分子 = 前一个分数的分母 + 分子
n = 20
fen_zi = 2
fen_mu = 1
for i in range(2,n+1):
    fen_zi,fen_mu = fen_mu+fen_zi,fen_zi
print(fen_zi,'/',fen_mu)

4.打印出所有的水仙花数,所谓水仙花数是指一个三位数,其各位数字立方和等于该数本身。
例如:153是一个水仙花数,因为153 = 1^3 + 5^3 + 3^3

for num in range(100,1000):   # 从所有三位数中依次取出一个数
    gei_wei = num % 10        # 算出这个三位数的个位、十位、百位数分别是什么
    shi_wei = num // 10 % 10
    bai_wei = num // 100
    if gei_wei **3 + shi_wei**3 + bai_wei **3 == num:    # 如果num满足水仙数的条件,就打印出来
        print(num)

#5.给一个正整数,要求:1、求它是几位数 2.逆序打印出各位数字
规律: 一个整数是几位数,就看这个数整除10,除几次后会变成0

#234 23 2 0
#1234 123 12 1 0

num = int(input('请输入一个正整数:'))
num2 = num
length = 0
while True:
    num //= 10
    length +=1
    if num == 0:
        break
print(length)

# 123410:取余:4  取整:123    12310:取余3 取整12  1210:取余2 取整1   110:取余1 取整0.1
for _ in range(length):
    print(num2%10,end='')
    num2 //= 10

1.一张纸的厚度大约是0.08mm,对折多少次之后能达到珠穆朗玛峰的高度(8848.13米)?
规律:n=1(折一次):厚度为0.08 * 21 ;n=2:厚度为0.08*22 ; n=n:厚度为0.08*2**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)
  1. 古典问题:有一对兔子,从出生后第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
  1. 将一个正整数分解质因数。例如:输入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 = 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)
  1. 一个数如果恰好等于它的因子之和,这个数就称为 "完数 "。例如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,'天')
  1. 某个公司采用公用电话传递数据,数据是四位的整数,在传递过程中是加密的,加密规则如下:
    #每位数字都加上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]   # 第二位,第三位 = 第三位,第二位
"""

学习资源推荐

上面都是一些软技能的干货分享,希望可以帮到正在入门学习 Python 的小伙伴们,下面是整理好的一些资料分享。
朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费】。

在这里插入图片描述
在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/63052.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

MySql使用MyCat分库分表(四)分片规则

视频学习地址:17-尚硅谷-垂直分库_哔哩哔哩_bilibili 笔记参考地址:MySQL 分库分表 | xustudyxus Blog (frxcat.fun) 分片规则 范围分片 介绍 根据指定的字段及其配置的范围与数据节点的对应情况, 来决定该数据属于哪一个分片。 配置 …

Angular 应用开发里使用 ForRoot 解决 Lazy Loaded Module 里单例行为丢失的问题

笔者在 Angular 实际项目开发中曾经遇到这样一个需求: 我们想创建一个共享模块,它将包含一个配置来设置布尔值(作为标志)以启用或禁用其他模块的某些功能。 其他模块可以在 Angular 应用程序的引导期间加载,也可以是延…

JVM基本常识

目录 内存区域划分 类加载 何时触发类加载? 双亲委派模型 GC GC回收那部分内存? 怎么回收? 怎么找垃圾(判定某个对象是否是垃圾) 具体怎么回收? 我的GitHub:Powerveil GitHub 我的Gitee:Powercs12…

痞子衡嵌入式:浅析IAR下调试信息输出机制之半主机(Semihosting)

大家好,我是痞子衡,是正经搞技术的痞子。今天痞子衡给大家分享的是IAR下调试信息输出机制之半主机(Semihosting)。 在嵌入式世界里,输出打印信息是一种非常常用的辅助调试手段,借助打印信息,我们可以比较容易地定位和…

由浅到深-模拟实现list

前言 作者:小蜗牛向前冲 名言:我可以接受失败,但我不能接受放弃 如果觉的博主的文章还不错的话,还请点赞,收藏,关注👀支持博主。如果发现有问题的地方欢迎❀大家在评论区指正。 目录 一 、见见…

Acrel-2000Z电力监控系统在某数据中心的应用-Susie 周

1、概述 随着网络和信息技术的快速发展,人们对“大数据”业务需求不断增长,为了满足日益增长的应用需求,数据的建设规模也在向超大型、园区级数据方向发展。通信、金融、商业等行业,面对未来数据业务的爆发式增长需求&#xff0c…

Go cobra 库学习

cobra既是一个用于创建强大现代CLI应用程序的库,也是一个生成应用程序和命令文件的程序。cobra被用在很多go语言的项目中,比如 Kubernetes、Docker、Istio、ETCD、Hugo、Github CLI等等 其实简单的来说,cobra就是一个自定义命令工具&#xff…

从IPC到分布式软总线的随笔

在Linux 系统中, 客观来说,缺乏相对开发者比较友好的进程间通信框架。谈到Linux上进程间通信,一般都会想起管道(匿名、有名)、信号/信号灯、共享内存、消息队列和socket。这些都是偏低层的技术,有没有方便开…

HummerRisk 入门3:开发手册

本文是 HummerRisk 的开发手册,介绍项目的结构及如何配置 HummerRisk 的开发环境和开发中的注意事项,快速参与到 HummerRisk 项目的开发中来。 一、项目结构 二、配置开发环境 1、环境准备 后端 HummerRisk 后端使用了 Java 语言的 Spring Boot 框架…

从今天起真正释放创造力 | Werner Vogels 在 re:Invent 2022带来多项开发者福音

对于开发者而言,成就感来自于每一次敲下代码后可实现的创造力,而不是把时间和精力消耗在写千篇一律又无法复用的“胶水”代码,或是在越来越复杂的软件栈面前,疲惫地写业务流程并尽量减少 Bug。 更加不堪的是,有时仅仅…

软件测试工程师涨薪攻略!3年如何达到30K!

1.软件测试如何实现涨薪 首先涨薪并不是从8000涨到9000这种涨薪,而是从8000涨到15K加到25K的涨薪。基本上三年之内就可以实现。 如果我们只是普通的有应届毕业生或者是普通本科那我们就只能从小公司开始慢慢往上走。 有些同学想去做测试,是希望能够日…

[附源码]计算机毕业设计基于springboot架构的博客平台设计

项目运行 环境配置: Jdk1.8 Tomcat7.0 Mysql HBuilderX(Webstorm也行) Eclispe(IntelliJ IDEA,Eclispe,MyEclispe,Sts都支持)。 项目技术: SSM mybatis Maven Vue 等等组成,B/S模式 M…

【电力系统】基于两阶段鲁棒优化算法的微网多电源容量配置附matlab代码

​✅作者简介:热爱科研的Matlab仿真开发者,修心和技术同步精进,matlab项目合作可私信。 🍎个人主页:Matlab科研工作室 🍊个人信条:格物致知。 更多Matlab仿真内容点击👇 智能优化算法…

01 初识HTML5

HTML5结构组成 HTML5主要是由标签组成的&#xff0c;如下代码就是HTML5的主要组成部分&#xff1a;<!DOCTYPE html> <!-- 文档声明标签&#xff0c;表示用html5解析 --> <html lang"zh-CN"> <!-- languangen 表示英文 “…

【保姆级·创建对象】如何通过Supplier创建对象

Spring创建对象的主要方式有 通过自定义BeanPostProcessor&#xff0c;生成代理对象InstantiationAwareBeanPostProcessor createBean() -> resolveBeforeInstantiation() 通过supplier创建对象 createBean() -> doCreateBean() -> createBeanInstance() -> obtai…

行业寒冬下逆势拿到50万offer,看看大牛是怎么做到的

年薪50万&#xff0c;这个薪水我以前想都不敢想&#xff0c;我一直以为月薪2万就是软件测试的天花板。当越来越多的同行拿到更高的薪水&#xff0c;我才明白&#xff0c;限制我薪水的不是行业天花板&#xff0c;而是我的技术实力。 每天陀螺一样两点一线的在家和公司之间往返&…

Nature文章使用认证Kamiya艾美捷抗胸腺嘧啶二聚体单抗方案

细胞内、外部环境中普遍存在的DNA损伤因素会破坏遗传信息的稳定性。紫外线损伤皮肤的机制之一是损伤细胞的DNA&#xff0c;形成“晒伤细胞”&#xff0c;诱发细胞内DNA产生丰富的变异&#xff0c;主要包括环丁烷嘧啶二聚体&#xff08;CPD&#xff0c;Cyclobutane pyrimidine d…

网络安全域内用户Hash获取方式

前言 在渗透测试的过程中&#xff0c;当我们已经是域管权限时&#xff0c;就可以实现提取所有域内用户的密码哈希以进行离线破解和分析&#xff0c;这是非常常见的一个操作&#xff0c;这些哈希值存储在域控制器(NTDS.DIT)中的数据库文件中&#xff0c;并带有一些其他信息&…

5-3:Spring整合Kafka

引入依赖 spring-kafka <!-- https://mvnrepository.com/artifact/org.springframework.kafka/spring-kafka --> <dependency><groupId>org.springframework.kafka</groupId><artifactId>spring-kafka</artifactId>/*可以注释掉&#xff…

小程序webView页面转发后,进入页面空白

小程序webView页面&#xff0c;在点击右上角按钮分享后&#xff0c;进入分享的链接页面空白 重新进入页面后&#xff0c;页面空白。使用电脑打开之后报错提示如下 一、排查页面转发后&#xff0c;页面地址有没有解码 webview页面转发后&#xff0c;小程序会将url参数转码&…