Python练习Day2

news/2024/10/20 1:24:51/

水仙花数

说明:水仙花数也被称为超完全数字不变数、自恋数、自幂数、阿姆斯特朗数,它是一个3位数,该数字每个位上数字的立方之和正好等于它本身,例如:1^3 + 5^3+ 3^3=153。

python"># 水仙花数
sum = 0
num = int(input("请输入一个数字: "))
temp = num
count = len(str(num))
while temp != 0:sum += (temp % 10) ** counttemp //= 10
if sum == num:print('%d是水仙花数' % num)
else:print('%d不是水仙花数' % num)

找出所有水仙花数

python"># 找出所有水仙花数
for num in range(100,1000):low = num % 10mid = num // 10 %10high = num //100if num == low**3 + mid**3 + high **3:print(num)

在上面的代码中,我们通过整除和求模运算分别找出了一个三位数的个位、十位和百位,这种小技巧在实际开发中还是常用的。用类似的方法,我们还可以实现将一个正整数反转,例如:将12345变成54321,代码如下所示。

python"># 正整数的翻转
num = int(input('num = '))
reversed_num = 0
while num >0 :
reversed_num = reversed_num * 10 + num % 10
num //=10
print(reversed_num)

百钱百鸡问题。

说明:百钱百鸡是我国古代数学家张丘建在《算经》一书中提出的数学问题:鸡翁一值钱五,鸡母一值钱三,鸡雏三值钱一。百钱买百鸡,问鸡翁、鸡母、鸡雏各几何?翻译成现代文是:公鸡5元一只,母鸡3元一只,小鸡1元三只,用100块钱买一百只鸡,问公鸡、母鸡、小鸡各有多少只?

python"># 百钱百鸡问题
for x in range(0,20):for y in range(0,33):z = 100-x-yif 5*x+3*y+z/3 == 100:print('公鸡:%d只,母鸡:%d只,小鸡:%d只' % (x,y,z))

CRAPS赌博游戏

说明:CRAPS又称花旗骰,是美国拉斯维加斯非常受欢迎的一种的桌上赌博游戏。该游戏使用两粒骰子,玩家通过摇两粒骰子获得点数进行游戏。简单的规则是:玩家第一次摇骰子如果摇出了7点或11点,玩家胜;玩家第一次如果摇出2点、3点或12点,庄家胜;其他点数玩家继续摇骰子,如果玩家摇出了7点,庄家胜;如果玩家摇出了第一次摇的点数,玩家胜;其他点数,玩家继续要骰子,直到分出胜负。

python"># CRAPS赌博游戏
# 我们设定玩家开始游戏时有1000元的赌注
# 游戏结束的条件是玩家输光所有的赌注from random import randintmoney = 1000
while money >0:print('你的总资产为: ',money)needs_go_on = Falsewhile True:debt = int(input('请下注:'))if 0<debt<=money:breakfirst = randint(1,6) + randint(1,6)print('玩家摇出了%d点' % first)if first==7 or first==11:print('玩家胜!')money += debtelif first==2 or first==3 or first ==12:print('庄家胜!')money -= debtelse:needs_go_on = Truewhile needs_go_on:needs_go_on = Falsecurrent = randint(1,6) + randint(1,6)print('玩家摇出了%d点' % current)if current == 7:print('庄家胜!')money -= debtelif current==first:print('玩家胜')money+=debtelse:needs_go_on = True
print('你破产啦~游戏结束啦!')

  1. 生成斐波那契数列的前20个数。

    说明:斐波那契数列(Fibonacci sequence),又称黄金分割数列,是意大利数学家莱昂纳多·斐波那契(Leonardoda Fibonacci)在《计算之书》中提出一个在理想假设条件下兔子成长率的问题而引入的数列,所以这个数列也被戏称为"兔子数列"。斐波那契数列的特点是数列的前两个数都是1,从第三个数开始,每个数都是它前面两个数的和,形如:1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, ...。斐波那契数列在现代物理、准晶体结构、化学等领域都有直接的应用。

python">a = 0
b = 1
for _ in range(20):a, b = b, a + bprint(a, end=' ')
  1. 找出10000以内的完美数

    说明:完美数又称为完全数或完备数,它的所有的真因子(即除了自身以外的因子)的和(即因子函数)恰好等于它本身。例如:6($6=1+2+3$)和28($28=1+2+4+7+14$)就是完美数。完美数有很多神奇的特性,有兴趣的可以自行了解。

        

python">import mathfor num in range(2, 10000):result = 0for factor in range(1, int(math.sqrt(num)) + 1):if num % factor == 0:result += factorif factor > 1 and num // factor != factor:result += num // factorif result == num:print(num)

 解释:

完美数(Perfect Number)是指一个数恰好等于它的因数之和(不包括它自身)。例如,6是一个完美数,因为它的因数是1, 2, 3,而1 + 2 + 3 = 6。

在检查一个数是否是完美数时,我们需要找到所有的因子,并将它们相加。因子是能够整除给定数的数。对于任何一个数num,它的因子成对出现,除了可能有一个例外,即如果num是一个完全平方数,那么它会有一个重复的因子。

例如,考虑数36,它的因子有1, 2, 3, 4, 6, 9, 12, 18, 36。其中,因子6出现了两次,因为36 = 6 * 6。在这种情况下,我们不想将6加两次到因数之和中,因为这会导致我们错误地计算因数之和。

为了避免重复计算相同的因子,我们可以只考虑小于或等于num的平方根的因子。然后,对于每个找到的因子factor,我们将factornum // factor(即num除以factor的结果)都加到因数之和中,除非factornum // factor相等,这意味着num是一个完全平方数,我们不想重复计算。

因此,条件 num // factor != factor 确保我们不会重复计算相同的因子。如果factornum // factor相等,那么我们只计算一次;如果不相等,那么我们分别计算它们。这样,我们就可以正确地计算出num的所有唯一因子之和,从而判断它是否是一个完美数。

  1. 输出100以内所有的素数

    说明:素数指的是只能被1和自身整除的正整数(不包括1)。

python">from math import sqrt# 100以内的素数for num in range(2,100):end = int(sqrt(num))is_Prime = Truefor x in range(2,end+1):if num % x == 0:is_Prime = Falsebreakif is_Prime :print('%d是素数' % num)# else:#     print('%d不是素数' % num)

  1. 是否为回文数

python">num = int(input('请输入一个正整数:'))
temp = num
num2 = 0
while temp > 0:num2 *= 10num2 +=temp%10temp //=10
if num == num2:print('%d是回文数' % num)
else:print('%d不是回文数' % num)


http://www.ppmy.cn/news/1426944.html

相关文章

【Cookie,Session,Token,JWT的区别】

一、Cookie Cookie 是在 HTTP 协议下&#xff0c;维护客户工作站上信息的一种方式。Cookie 是由 Web 服务器保存在用户浏览器上的小文本数据文件&#xff0c;它可以包含有关用户的信息。cookie是不可跨域的&#xff0c;每个cookie都会绑定一个单一的域名&#xff0c;并只能在指…

C#硬件接口开发------一文了解WMI

&#x1f388;个人主页&#xff1a;靓仔很忙i &#x1f4bb;B 站主页&#xff1a;&#x1f449;B站&#x1f448; &#x1f389;欢迎 &#x1f44d;点赞✍评论⭐收藏 &#x1f917;收录专栏&#xff1a;C# 硬件接口开发 &#x1f91d;希望本文对您有所裨益&#xff0c;如有不足…

UE5增强输入系统 Enhanced Input

关键字&#xff1a; Enhanced Input 、 输入、映射、事件、鼠标、键盘、键鼠、动作、Trigger、触发器、 疑问&#xff1a; 新输入系统怎么做一个基础的案例&#xff1f;Trigger修改器中每个项都是什么功能&#xff1f;功能边界问题&#xff1a;如时刻、时段、单次事件、持续事…

产品经理常用工具汇总

英文名称中文名称描述Axure原型原型图&#xff0c;流程图&#xff0c;框架图&#xff0c;原型图&#xff1b;Axhub团队原型共享Axure原型团队共享&#xff0c;链接转发&#xff1b;iconfont阿里矢量图标图标下载&#xff0c;协助原型和方案&#xff1b;visio流程图 业务流程图&…

上海计算机学会2022年11月月赛C++丙组T3最长平台

题目描述 给定一个整数数列 a1​,a2​,…,an​&#xff0c;请找出最长平台。所谓平台&#xff0c;就是指数列中一段连续的、完全相等的数字&#xff0c;单个数字也可以成为一个平台。最长平台可能不止一个&#xff0c;在找到最长平台的同时&#xff0c;输出最长平台的数量。 …

追溯历史:SIEM 中的生成式人工智能革命

作者&#xff1a;来自 Elastic Mike Nichols, Mike Paquette 网络安全领域仿佛是现实世界的一个映射&#xff0c;安全运营中心&#xff08;security operation center - SOC&#xff09;就像是你的数字警察局。网络安全分析师就像是警察&#xff0c;他们的工作是阻止网络犯罪分…

MacOS安装openMP报错该如何处理

在 macOS 上安装 OpenMP 可能会遇到一些问题&#xff0c;特别是因为 macOS 不像 Linux 系统那样默认支持 OpenMP。以下是一种可能的解决方法&#xff1a; 步骤一&#xff1a;安装 Homebrew 1.打开终端应用程序。 2.运行以下命令安装 Homebrew&#xff1a; /bin/bash -c &qu…

代码托管(二)git(1)介绍

一、git相关 git github gitlub 二、gitlub签名认证 使用ssh克隆代码&#xff0c;使用gpg签名提交代码。 1、ssh签名 一对公钥和密钥&#xff0c;公钥复制到gitlub上。步骤如下 1.1、先在本地生成密钥和公钥 &#xff08;1&#xff09;配置用户名和邮箱 git config --g…