百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 热门文章 > 正文

python经典编程解题实例

bigegpt 2024-08-04 11:34 3 浏览

题目1

有四个数字:1、2、3、4,能组成多少个互不相同且无重复数字的三位数?各是多少?

可填在百位、十位、个位的数字都是1、2、3、4。组成所有的排列后再去 掉不满足条件的排列。

for a in range(1, 5):
 for b in range(1, 5):
 for c in range(1, 5):
 if a != b and b != c and a != c:
 print(a, b, c)
 pass
 pass

题目2

企业发放的奖金根据利润提成。利润(I)低于或等于10万元时,奖金可提10%;利润高于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可提成7.5%;20万到40万之间时,高于20万元的部分,可提成5%;40万到60万之间时高于40万元的部分,可提成3%;60万到100万之间时,高于60万元的部分,可提成1.5%,高于100万元时,超过100万元的部分按1%提成,从键盘输入当月利润I,求应发放奖金总数?

请利用数轴来分界,定位。注意定义时需把奖金定义成长整型。

arr = (0, 10, 20, 40, 60, 100)
rat = (0, 10, 7.5, 5, 3, 1.5, 1)
 
pro = float(input('净利润(万元):'))
fit = 0
 
for i in range(1, len(arr)):
 if (pro > arr[i]):
 fit += (arr[i] - arr[i - 1]) * (rat[i] / 100)
 else:
 fit += (pro - arr[i - 1]) * (rat[i] / 100)
 break
 
print('奖金(元):', fit * 10000)

题目3

一个整数,它加上100和加上268后都是一个完全平方数,请问该数是多少?

在10000以内判断,将该数加上100后再开方,加上268后再开方,如果开方后的结果满足如下条件,即是结果。

import math
 
for i in range(10000):
 n = math.sqrt(i + 100)
 m = math.sqrt(i + 268)
 if n % 1 == 0 and m % 1 == 0:
 print(i)

题目4

输入某年某月某日,判断这一天是这一年的第几天?

以3月5日为例,应该先把前两个月的加起来,然后再加上5天即本年的第几天,特殊情况,闰年且输入月份大于2时需考虑多加一天。

cal = input('日期:')
 
date = cal.split('-') # 拆分日期
 
year = int(date[0])
month = int(date[1])
day = int(date[2])
 
arr = [0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]
 
num = 0
 
if ((year % 4 == 0) and (year % 100 != 0)) or (year % 400 == 0):
 arr[2] = 29
 
for i in range(1, len(arr)):
 if month > i:
 num += arr[i]
 else:
 num += day
 break
 
print('天数:', num)

题目5

输入三个整数x,y,z,请把这三个数由小到大输出。

我们想办法把最小的数放到x上,先将x与y进行比较,如果x>y则将x与y的值进行交换,然后再用x与z进行比较,如果x>z则将x与z的值进行交换,这样能使x最小。

arr_str = input('请输入三个整数:\n')
 
arr = arr_str.split()
 
for i in range(len(arr)):
 arr[i] = int(arr[i])
 
arr.sort(reverse=False)
 
print('排序结果:\n' + str(arr))

题目6

斐波那契数列。

斐波那契数列(Fibonacci sequence),又称黄金分割数列,指的是这样一个数列:0、1、1、2、3、5、8、13、21、34、……。

arr = [0, 1]
 
tmp, num = 0, 1
 
dep = 20 # 数列长度
 
for i in range(dep - 2):
 tmp, num = num, tmp + num
 arr.append(num)
 
print(arr)

题目7

将一个列表的数据复制到另一个列表中。

使用列表[:]。

origin = ['javascript', 'php', 'python']
refer = origin
copy = origin[:] # origin.copy()
 
print('变量(0x%x): %s' % (id(origin), str(origin)))
print('引用(0x%x): %s' % (id(refer), str(refer)))
print('复制(0x%x): %s' % (id(copy), str(copy)))

题目8

输出 9*9 乘法口诀表。

分行与列考虑,共9行9列,i控制行,j控制列。

for i in range(1, 10):
 for j in range(1, i + 1):
 exp = '%d * %d = %d' % (i, j, i * j)
 print(exp, end='\t')
 print()

题目9

模拟Linux用户登录。

验证账号和密码,若失败则延迟三秒输出错误信息。

import time
 
global user, name
 
user = {
 'woider': '3243',
}
 
 
def login():
 global name
 name = input('Username:')
 pswd = input('Password:')
 if name not in user:
 return False
 return user[name] == pswd
 
 
while (not login()):
 time.sleep(3) # 暂停3秒
 print('Authentication failure')
 
print(name + '@localhost:~
)

题目10

格式化输出当前时间。

使用 time 模块,格式为 yyyy-mm-dd HH:mm:ss。

import time
 
format = '%Y-%m-%d %H:%M:%S'
local = time.localtime(time.time())
 
print(time.strftime(format, local))

题目11

古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?

兔子的规律为数列1,1,2,3,5,8,13,21....

f1, f2 = 1, 1
for i in range(1, 22):
 print('%12ld %12ld' % (f1, f2), end='')
 if (i % 3) == 0:
 print()
 f1 = f1 + f2
 f2 = f1 + f2

题目12

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

判断素数的方法:用一个数分别去除2到sqrt(这个数),如果能被整除,则表明此数不是素数,反之是素数。

from math import sqrt
 
min = 101
max = 200
 
prime = list()
 
for i in range(min, max + 1):
 temp = int(sqrt(i))
 flag = True # 是否为素数
 for j in range(2, temp + 1):
 if (i % j) == 0:
 flag = False
 break
 if flag == True:
 prime.append(i)
 
print('%d-%d 之间共有 %d 个素数' % (min, max, len(prime)))
print(prime)

题目13

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

利用for循环控制100-999个数,每个数分解出个位,十位,百位。

arr = list()
 
for i in range(100, 1000):
 a = int(i / 100) % 10
 b = int(i / 10) % 10
 c = int(i / 1) % 10
 if i == a ** 3 + b ** 3 + c ** 3:
 arr.append(i)
 
print('水仙花数:' + str(arr))

题目14

将一个正整数分解质因数。例如:输入90,打印出90=233*5。

对n进行分解质因数,应先找到一个最小的质数k,然后按下述步骤完成: (1)如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即可。 (2)如果n<>k,但n能被k整除,则应打印出k的值,并用n除以k的商,作为新的正整数你n,重复执行第一步。 (3)如果n不能被k整除,则用k+1作为k的值,重复执行第一步。

num = int(input('input num: '))
arr = [] # 质因数列表
 
tmp = num
while tmp != 1:
 pri = 2
 while pri != (num + 1):
 if (tmp % pri) == 0:
 tmp = tmp // pri
 arr.append(pri)
 else:
 pri += 1
 
exp = ' * '.join(map(str, arr))
print('%d = %s' % (num, exp))

题目15

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

程序分析:(a>b)?a:b这是条件运算符的基本例子。

score = int(input('输入成绩:'))
rank = None
 
if 0 <= score and score < 60:
 rank = 'C'
elif 60 <= score and score < 90:
 rank = 'B'
elif 90 <= score and score <= 100:
 rank = 'A'
 
if rank != None:
 print('%d 属于等级 %s' % (score, rank))
else:
 print('成绩应在 0-100 之间')

题目16

输出指定格式的日期。

使用 datetime 模块。

import datetime
 
# 日期格式
form = '%Y-%m-%d'
 
# 日期对象
date1 = datetime.date(1945, 8, 15)
print('抗战胜利:', date1.strftime(form))
 
# 日期运算
date2 = date1 + datetime.timedelta(days=18)
print('二战结束:', date2.strftime(form))
 
# 日期替换
date3 = date2.replace(year=1949, month=10, day=1)
print('开国大典:', date3.strftime(form))
 
# 当前日期
date4 = datetime.date.today()
print('当前日期:', date4.strftime(form))

题目17

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

利用while语句,条件为输入的字符不为'\n'。

class Code:
 content = '' # 代码
 letters = 0 # 字母
 space = 0 # 空格
 digit = 0 # 数字
 others = 0 # 字符
 
 # 构造函数
 def __init__(self, content):
 self.content = content
 
 # 分析代码
 def analysis(self):
 for c in self.content:
 if c.isalpha():
 self.letters += 1
 elif c.isspace():
 self.space += 1
 elif c.isdigit():
 self.digit += 1
 else:
 self.others += 1
 
 # 展示结果
 def showData(self):
 form = '字母(%d) 空格(%d) 数字(%d) 其他字符(%d)'
 data = (self.letters, self.space, self.digit, self.others)
 print(form % data)
 
 
content = input('请输入一段代码:\n')
 
code = Code(content)
code.analysis() # 分析
code.showData() # 展示

题目18

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

关键是计算出每一项的值。

a = int(input('input a: '))
n = int(input('input n: '))
 
x = 0 # 各项值
l = [] # 值集合
 
for i in range(n):
 x += a * (10 ** i)
 l.append(x)
 
exp = ' + '.join(map(str, l))
res = sum(l)
 
print('%s = %d' % (exp, res))

题目19

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

请参照程序Python 练习实例14。

RAN = 1000 # 完数范围
 
for i in range(2, RAN + 1):
 l = [] # 因数列表
 for j in range(1, i):
 if (i % j) == 0:
 l.append(j)
 if sum(l) == i:
 print(i, ':', l)

题目20

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

利用循环计算每一次小球落地的高度。

h = 100 # 自由落体高度
n = 10 # 落地次数
 
s = [] # 每次下落高度
 
for i in range(n):
 s.append(h)
 h /= 2
 
print('总高度:', 2 * sum(s) - s[0])
print('反弹高度:', s[-1] / 2)
 
# 等比数列求解法
q = 1 / 2
a1 = 100
 
a11 = a1 * (q ** (11 - 1))
s10 = a1 * ((1 - q ** 10) / (1 - q))
 
print('总高度:', 2 * s10 - a1)
print('反弹高度:', a11)

题目21

猴子第一天摘下若干个桃子,当即吃了一半,还不瘾,又多吃了一个第二天早上又将剩下的桃子吃掉一半,又多吃了一个。以后每天早上都吃了前一天剩下的一半零一个。到第10天早上想再吃时,见只剩下一个桃子了。求第一天共摘了多少。

采取逆向思维的方法,从后往前推断。

# f(n) = (f(n + 1) / 2) - 1
 
arr = [] # 每天剩余桃子数
arr.insert(0, 1)
 
for i in range(9, 0, -1):
 n = (arr[0] + 1) * 2
 arr.insert(0, n)
 
print(arr)

题目22

两个乒乓球队进行比赛,各出三人。甲队为a,b,c三人,乙队为x,y,z三人。已抽签决定比赛名单。有人向队员打听比赛的名单。a说他不和x比,c说他不和x,z比,请编程序找出三队赛手的名单。

先进行排列组合,再挑选符合要求的组合。

T1 = ('a', 'b', 'c')
T2 = ('x', 'y', 'z')
 
arr = [] # 可能的组合
 
 
def comb(i, j, k):
 c1 = T1[0] + '-' + T2[i]
 c2 = T1[1] + '-' + T2[j]
 c3 = T1[2] + '-' + T2[k]
 return tuple([c1, c2, c3])
 
 
# 找出 x,y,z 的所有组合
for i in range(3):
 for j in range(3):
 for k in range(3):
 if (i == j) or (i == k) or (j == k):
 continue
 arr.append(comb(i, j, k))
 
# 过滤不符合要求的组合
for g in arr:
 if ('a-x' in g) or ('c-z' in g) or ('c-x' in g):
 continue
 print(g)

题目23

利用循环打印菱形

先把图形分成两部分来看待,前四行一个规律,后三行一个规律,利用双重for循环,第一层控制行,第二层控制列。

SIZE = 5
SHOW = ' *'
HIDE = ' '
 
# 坐标系构建法
for y in range(SIZE - 1, -SIZE, -1):
 for x in range(-SIZE + 1, SIZE, 1):
 if (y > x - SIZE) and (y < x + SIZE) and \
 (y > -x - SIZE) and (y < -x + SIZE):
 print(SHOW, end='')
 else:
 print(HIDE, end='')
 print()

题目24

有一分数序列:2/1,3/2,5/3,8/5,13/8,21/13...求出这个数列的前20项之和。

请抓住分子与分母的变化规律。

arr = [] # f(n)/g(n) = (f(n-1) + g(n-1))/f(n-1)
 
fn, gn = 1, 1
 
for i in range(20):
 fn, gn = fn + gn, fn
 arr.append('%d/%d' % (fn, gn))
 
print(eval('+'.join(arr)))

题目25

求1+2!+3!+...+20!的和。

此程序只是把累加变成了累乘。

from math import factorial
 
arr = [] # 阶乘列表
 
for i in range(1, 21):
 arr.append(factorial(i))
 
exp = '1! + 2! + 3! + ... + 20!'
print('{0} = {1}'.format(exp, sum(arr)))
 

题目26

利用递归方法求5!。

递归公式:fn=fn_1*4!

def factor(n):
 if not isinstance(n, (int)):
 raise TypeError()
 if n < 1:
 raise Exception()
 if n == 1:
 return 1
 return factor(n - 1) * n
 
 
n = 5
 
print('%d! = %d' % (n, factor(n)))
 

题目27

利用递归函数调用方式,将所输入的5个字符,以相反顺序打印出来。

递归实际上是一种函数堆栈。

def reverse(str):
 if len(str) == 0:
 return str
 return reverse(str[1:]) + str[0]
 
 
poetry = input('五言绝句:')
print(reverse(poetry))

题目28

有5个人坐在一起,问第五个人多少岁?他说比第4个人大2岁。问第4个人岁数,他说比第3个人大2岁。问第三个人,又说比第2人大两岁。问第2个人,说比第一个人大两岁。最后问第一个人,他说是10岁。请问第五个人多大?

利用递归的方法,递归分为回推和递推两个阶段。要想知道第五个人岁数,需知道第四人的岁数,依次类推,推到第一人(10岁),再往回推。

# f(n) = f(n-1) + 2
 
def age(n):
 if n == 1:
 return 10
 return age(n - 1) + 2
 
 
print(age(5))
 

题目29

给一个不多于5位的正整数,要求:一、求它是几位数,二、逆序打印出各位数字。

学会分解出每一位数。

num = int(input('正整数:'))
 
arr = [] # num 的每一位
 
while num != 0:
 arr.insert(0, str(num % 10))
 num = num // 10
 
print('%s 为 %d 位数' % (''.join(arr), len(arr)))
 
arr.reverse() # 反向列表中元素
 
print('倒序输出', ''.join(arr))

题目30

一个5位数,判断它是不是回文数。

回文数,个位与万位相同,十位与千位相同。

num = str(int(input('输入数字:')))
 
# 判断是否为回文
def palindrome(s):
 for i in range(len(s) // 2):
 if s[i] != s[-i - 1]:
 return False
 return True
 
 
print('是否为回文数:', palindrome(num))

相关推荐

科氪 | 华硕天选6系列正式发布,搭载满功耗RTX 5060实际到手5999元起

5月19日晚,华硕旗下潮玩新次元游戏本天选6系列正式发布。作为Z世代青年的潮酷游戏装备,天选6系列再一次印证了其出色的综合实力。搭载满功耗RTX5060笔记本电脑GPU的天选6Pro以及天选6皆...

最新历史最低价显卡汇总!低端高端一网打尽

文|宋金戈责编|吕东兴总编|唐迪近期开展的618大促,各个品类尤其是数码科技好物的产品优惠都诚意满满,而作为消费者最关心的大类之一,显卡在最近同样表现不俗——华硕、技嘉等多个品牌,从1660s...

DNF:南山必胜客“败诉”,TX被DD373实锤,谁说玩家只有使用权?

TX和DD373的官司终于落下帷幕,南山必胜客终于中断了传奇。TX这一次被判定败诉。其中关于游戏账号和虚拟财产的问题,最受玩家关注。之前TX所说的:游戏账号不是玩家私有财产,游戏币更不是,只有使用权!...

Switch最新SX OS破解系统发布:可运行国行卡带xci镜像了

本周,TX团队(Team-Xecuter)发布了SXOS自制系统的最新版本,v2.9.5Beta,该版本支持了任天堂最新的V10.0.0和v10.0.1固件,同时改善了兼容性,优化了本地联机的稳定...

神舟战神TX8R5 QHD游戏本电脑今晚开售:2.5K屏+RTX4060,6999元

IT之家4月9日消息,神舟战神TX8R5QHD游戏本电脑今晚12点正式开售,仅有16GB+512GB一个版本可选,售价6999元。神舟战神TX8R5QHD搭载13代酷...

开创第三代手游商业模式《武极天下》推无商城玩法

翻阅游戏论坛与贴吧,大家对网络游戏的一些“坑爹”的设定抱怨不已,不是游戏职业设定不合理,就是游戏太烧钱,在游戏中被碾压的抬不起头,最后从玩游戏变成了被游戏玩,俨然游戏本质完全变味。由巨人移动自主研发并...

真满血Gen5电竞存储神装!佰维X570 Pro天启高速固态硬盘测评

2025一开年,对于存储行业来说,就是速度狂飙的开局。各固态硬盘品牌PCIe5.0SSD纷纷亮相,开启了新一轮的性能PK。在2024年异常活跃的佰维科技,也于CES期间推出了佰维X570PRO...

Kingston FURY Renegade G5评测 最速PCIe5.0固态硬盘诞生

【ZOL中关村在线原创评测】说起KingstonFURYRenegade叛逆者的大名,相信PCDIY玩家都知道这是金士顿高端存储的代名词,尤其是内存产品给人印象尤为深刻。实际上它还有固态硬盘系列...

《武极天下》力挺苹果TestFlight创业界先河

关于革旧鼎新,有人说就像是摸石头过河,在摸索中前行。一场正真的创新改革会带来什么?在数字行业,苹果公司的每一个产品都代表着一个时代的开启,它独立的操作系统、顺应用户需求的体验设计,在十几年时间内收获了...

闪迪至尊超极速移动固态硬盘USB4版评测 超越SSD的三防猛兽

移动固态硬盘,凭借TB级的容量和远超传统移动机械硬盘几倍、十几倍的速度,当仁不让地成为高效移动存储的代名词,为4K/8K超高清内容创作、海量文件备份带来了超乎想象的效率提升。国际知名品牌SanDisk...

RTX5070笔记本有哪些:游戏笔记本电脑哪个牌子好?

RTX5070游戏本,个人其实不是很喜欢,对于新款显卡,要不就考虑RTX5060,要不就考虑12GB显存的RTX5070Ti这样好一些,从RTX5070显卡的游戏本的量,也能看出来,估计5060会更多...

破军天下安装指南详解 游戏安装方法介绍

破军天下游戏怎么正确安装?破军天下安装方法是什么?对于破军天下中的安装问题,今天安趣网小编就为各位玩家小伙伴来好好的讲解下,让我们一起来看看,破军天下怎么正确安装游戏的吧!希望大家喜欢!安卓系统(An...

从高性能轻薄本到硬核电竞本 华硕天选新品解锁全场景体验

来源:环球网【环球网科技综合报道】5月19日,华硕天选多款笔记本新品正式发布。其中,14英寸轻薄全能本标杆华硕天选Air2025正式发布,显卡升级至GeForceRTX5060笔记本电脑GPU...

笔记本无线网卡有哪几种 有必要对其升级吗?

无线网卡是很多朋友购买笔记本时容易忽视的部分,相比较处理器、内存、显卡和硬盘,无线网卡几乎不可选,而且很少有厂商提到自家产品采用的无线网卡型号。大家可能遇到过这种情况:为什么手机可以连接到5Ghz,而...

下班了才发现,你的手机里藏着5个定时炸弹!

各位打工人累了一天终于可以躺平刷手机了吧?且慢!工信部最新通知,有些App比加班还可怕!它们可能正在偷偷收集你的信息,比你的老板还要了解你!今天就让我们一起来扒一扒这些“职场内鬼“,看看你的手机里有没...