python简单实例训练(21~30)


Posted in Python onNovember 15, 2017

注意:我用的python2.7,大家如果用Python3.0以上的版本,请记得在print()函数哦!如果因为版本问题评论的,不做回复哦!!

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

程序分析:对n进行分解质因数,应先找到一个最小的质数k,然后按下述步骤完成:

(1)如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即可。

(2)如果n!=k,但n能被k整除,则应打印出k的值,并用n除以k的商,作为新的正整数你n,重复执行第一步。

(3)如果n不能被k整除,则用k+1作为k的值,重复执行第一步。

注意:要知道 format 这个函数,其实就是格式化,与 print 差不多,具体可参考https://3water.com/article/63672.htm

方法一:只用循环

# -*- coding: UTF-8 -*-
while True:
 n = input("请输入一个数:")
 #这里有逗号是为了保证它输出后不自动换行,下同
 print '{} = '.format(n), 
 #判断你输入的是不是正确格式
 if not isinstance(n, int) or n <= 0 :
  print '请输入一个正确的数字 !' 
 #如果你是输入的是 1,那只输出 1
 if n in [1] : 
  print '{}'.format(n) 
 while n >= 2:
  for i in range(2,n + 1):
   if n % i == 0:
    n /= i  #n 等于 n/i
    if n == 1: 
     print i ,
    else :  # index 一定是素数
     print '{} *'.format(i),
    break
 print  #换行咯

方法二:定义函数

# -*- coding: UTF-8 -*-
def reduceNum(n):
 print '{} = '.format(n),
 if not isinstance(n, int) or n <= 0 :
  print '请输入一个正确的数字 !'
  exit(0)
 elif n in [1] :
  print '{}'.format(n)
 while n not in [1] : # 循环保证递归
  for i in range(2, n + 1) :
   if n % i == 0:
    n /= i # n 等于 n/i
    if n == 1: 
     print i 
    else : # i 一定是素数
     print '{} *'.format(i),
    break

reduceNum(100)
reduceNum(9)

输出:
100 = 2 * 2 * 5 * 5
9 = 3 * 3

方法三:用列表 append 函数,这里只是用列表的形式输出了所有x的因子

# -*- coding: UTF-8 -*-
while True:
 x = input("pls input a number:")
 ret = []
 while x > 1:
  for v in range(2,x + 1):
   if x % v == 0:
    ret.append(v)
    x /= v
    break
 print ret

 输出:
  pls input a number:9
  [3, 3]

说明:其实两种方法大同小异,没什么区别。

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

程序分析:关键是计算出每一项

# -*- coding: UTF-8 -*-
Tn = 0
Sn = [] #用来存储数字个数
n = int(raw_input('输入你想要相加的数字个数 n = :')) #控制你要相加的次数
a = int(raw_input('输入数字 a = :')) #真正要加的数字
for count in range(n):
 Tn = Tn + a 
 a = a * 10
 Sn.append(Tn)#每加一个数就放在Sn列表中
 print Tn

 #lambda这个函数比较强大,具体用法可以看下资料
Sn = reduce(lambda x,y : x + y,Sn)
print Sn

输入你想要相加的数字个数 n = :5
输入数字 a = :6
6
66
666
6666
66666
74070

用到的函数:

1.python中的reduce内建函数是一个二元操作函数,他用来将一个数据集合(链表,元组等)中的所有数据进行下列操作:用传给reduce中的函数 func()(必须是一个二元操作函数)先对集合中的第1,2个数据进行操作,得到的结果再与第三个数据用func()函数运算,最后得到一个结果。

具体可参考https://3water.com/article/128310.htm

2.lambda函数,看连接https://3water.com/article/128311.htm

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

程序分析:请参照程序Python 练习实例14。只要在后面加上判断条件就可以了,注意,要在输出因子的时候加上1,注意看题,1是任何数的因子,所以不能漏掉

# -*- coding: UTF-8 -*-
import random
import time

while True:
 x = random.randint(1,1000)
 #因为后面求质数要修改x的值,所以先把x保存起来备用
 s = x 
 factors = [1] #1是任何数的因子
 while x > 1:
  #上限取值可以是x,即因子也可以是x本身,这个大家都懂得
  for v in range(2,x + 1):
   if x % v == 0:
    factors.append(v) 
    #找到了当前的最小因子,重置继续找下一符合条件的最小因子
    x /= v
    #由于break是跳出当前的循环,所以这里的break是跳出for循环
    break
 print "所有因子是 %s,所以"%(factors),
 if sum(factors) == s: #这里就是判断函数了
  print "%d 是完数"%(s)
 else:
  print "%d 不是完数"%(s)
time.sleep(1) #为防止程序卡顿,我睡一秒输出一个

输出:
所有因子是 [1, 2, 2, 2, 31],所以: 248 不是完数
所有因子是 [1, 2, 2, 2, 73],所以: 584 不是完数
所有因子是 [1, 823],所以: 823 不是完数
所有因子是 [1, 281],所以: 281 不是完数
所有因子是 [1, 467],所以: 467 不是完数
所有因子是 [1, 2, 359],所以: 718 不是完数
所有因子是 [1, 2, 7, 47],所以: 658 不是完数
所有因子是 [1, 751],所以: 751 不是完数
所有因子是 [1, 3, 71],所以: 213 不是完数

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

程序分析:用数学的角度很好理解是吧,但是这里要把字母转化成ASCII码来做哦!

# -*- coding: UTF-8 -*-

for i in range(ord('x'),ord('z') + 1):
 for j in range(ord('x'),ord('z') + 1):
  if i != j:
   for k in range(ord('x'),ord('z') + 1):
    if (i != k) and (j != k):
     if (i != ord('x')) and (k != ord('x')) and (k != ord('z')):
      print 'order is a -- %s\t b -- %s\tc--%s' % (chr(i),chr(j),chr(k))

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

程序分析:请抓住分子与分母的变化规律。可以看出,分母是斐波那契数列哦~

方法一:第一个分数的分子分母之和是第二个数的分子。

# -*- coding: UTF-8 -*-

a = 2.0  #第一个数的分母
b = 1.0  #第一个数的分子
s = 0   #前20项的和
for n in range(1,21):
 s += a / b
 t = a  #先把分子保存到t
 a = a + b #分子是前一个分数的分子分母之和
 b = t  #分子分母交换
print s

方法二:

# -*- coding: UTF-8 -*-

a = 2.0
b = 1.0
s = 0.0
for n in range(1,21):
 s += a / b
 b,a = a , a + b
print s

方法三:

# -*- coding: UTF-8 -*-

a = 2.0
b = 1.0
l = []
for n in range(1,21):
 b,a = a,a + b
 l.append(a / b)
print reduce(lambda x,y: x + y,l)

26.题目:求1+2!+3!+…+20!的和。

程序分析:此程序只是把累加变成了累乘。想一想阶乘怎么算的?n!=n×(n-1)×(n-2)×(n-3)×…×1,所以只需要一个遍历,把n以内的数字相乘后,再加起来即可。

方法一:

# -*- coding: UTF-8 -*-

n = 0
s = 0
t = 1
for n in range(1,21):
 t *= n #这里t就是20以内每个数的阶乘
 s += t #把每次得到的阶乘值加到s
print '1! + 2! + 3! + ... + 20! = %d' % s

方法三:这里用定义函数的方法,使用sum函数。

# -*- coding: UTF-8 -*-

s = 0
l = range(1,21)
def op(x):
 r = 1
 for i in range(1,x + 1):
  r *= i
 return r

s = sum(map(op,l)) 
print '1! + 2! + 3! + ... + 20! = %d' % s

输出:1! + 2! + 3! + ... + 20! = 2561327494111820313

这里补充一下map()函数的用法:

很简单,第一个参数接收一个函数名,第二个参数接收一个可迭代对象

# -*- coding: UTF-8 -*-
ls = [1,2,3]
rs = map(str, ls)
#打印结果 ['1', '2', '3']

lt = [1, 2, 3, 4, 5, 6]
def add(num):
 return num + 1

rs = map(add, lt)
print rs 
#打印结果[2,3,4,5,6,7]

27.题目:利用递归方法求5!。

程序分析:递归公式:fn=fn_1*4!递归的方法就是自己调用自己。

# -*- coding: UTF-8 -*-
def jiecheng(n):
 if n <= 1:
  return 1
 else:
  return n * jiecheng(n-1)
print jiecheng(5)

输出:120

28.题目:将所输入的5个字符,以相反顺序打印出来。

方法一:利用递归函数调用方式

# -*- coding: UTF-8 -*-

def output(s,l):
 if l==0:
  return
 print (s[l-1])
 output(s,l-1)

s = raw_input('Input a string:')
l = len(s)
output(s,l)

输出:Input a string:1234
4
3
2
1

方法二:用reverse函数

# -*- coding: UTF-8 -*-
a = [1,2,3,4,5]
a.reverse()
print a

 或者:

# -*- coding: UTF-8 -*-
s = list(raw_input('Input a string:'))
s.reverse()
print s

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

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

方法一:这个很简单吧,就是每次循环都加2,循环4次就好了啊!

# -*- coding: UTF-8 -*-
x = 10
for i in range(1,5):
 x = x + 2
print x

方法二:定义函数的方法

# -*- coding: UTF-8 -*-
def age(n):
 if n == 1: 
  x = 10
 else: 
  x = age(n - 1) + 2
 return x
print age(5)

29.题目:一个5位数,判断它是不是回文数。即12321是回文数,个位与万位相同,十位与千位相同。

程序分析:将这个五位数从中间分开,根据对称性去切,然后比较是否相等。

# -*- coding: UTF-8 -*-
a = int(raw_input("请输入一个数字:"))
x = str(a)
flag = True

for i in range(len(x)/2):
 if x[i] != x[-i - 1]: #如果不相等,直接跳出循环,直接判断不是回文数
 flag = False
 break
if flag:
 print "%d 是一个回文数!" % a
else:
 print "%d 不是一个回文数!" % a

输出:
请输入一个数字:
15651
15651 是一个回文数!

30.题目:请输入星期几的第一个字母来判断一下是星期几,如果第一个字母一样,则继续判断第二个字母。

程序分析:用情况语句比较好,如果第一个字母一样,则判断用情况语句或if语句判断第二个字母。。哇,这个题应该好简单啊~~先看一下星期的单词都有哪些“Monday Tuesday Wednesday Thursday Friday Saturday Sunday”,所有只有“T”和“S”要判断第二个字母。

# -*- coding: UTF-8 -*-

 letter = raw_input("please input:")
 #while letter != 'Y':
 if letter == 'S':
  print ('please input second letter:')
  letter = raw_input("please input:")
  if letter == 'a':
   print ('Saturday')
  elif letter == 'u':
   print ('Sunday')
  else:
   print ('data error')

 elif letter == 'F':
  print ('Friday')

 elif letter == 'M':
  print ('Monday')

 elif letter == 'T':
  print ('please input second letter')
  letter = raw_input("please input:")

  if letter == 'u':
   print ('Tuesday')
  elif letter == 'h':
   print ('Thursday')
  else:
   print ('data error')

 elif letter == 'W':
  print ('Wednesday')
 else:
  print ('data error')

这篇文章就介绍到这了,后面三水点靠木小编将继续为大家分享更多的关于python的一些实例资料。

Python 相关文章推荐
python在windows命令行下输出彩色文字的方法
Mar 19 Python
Python中Continue语句的用法的举例详解
May 14 Python
python提取字典key列表的方法
Jul 11 Python
举例讲解Python中的Null模式与桥接模式编程
Feb 02 Python
Python中的time模块与datetime模块用法总结
Jun 30 Python
Python 使用os.remove删除文件夹时报错的解决方法
Jan 13 Python
Python数据分析中Groupby用法之通过字典或Series进行分组的实例
Dec 08 Python
tensorflow 1.0用CNN进行图像分类
Apr 15 Python
在pycharm中使用git版本管理以及同步github的方法
Jan 16 Python
Django中使用session保持用户登陆连接的例子
Aug 06 Python
python logging通过json文件配置的步骤
Apr 27 Python
Django表单提交后实现获取相同name的不同value值
May 14 Python
python下10个简单实例代码
Nov 15 #Python
python获取多线程及子线程的返回值
Nov 15 #Python
python使用threading获取线程函数返回值的实现方法
Nov 15 #Python
python enumerate函数的使用方法总结
Nov 15 #Python
Python set常用操作函数集锦
Nov 15 #Python
python机器学习库常用汇总
Nov 15 #Python
python爬虫系列Selenium定向爬取虎扑篮球图片详解
Nov 15 #Python
You might like
php中AES加密解密的例子小结
2014/02/18 PHP
JS焦点图切换,上下翻转
2011/05/12 Javascript
地址栏传递中文参数乱码在js里用escape转码
2013/08/28 Javascript
jquery datatable后台封装数据示例代码
2014/08/07 Javascript
js获取内联样式的方法
2015/01/27 Javascript
Javascript实现div的toggle效果实例分析
2015/06/09 Javascript
使用ngView配合AngularJS应用实现动画效果的方法
2015/06/19 Javascript
js实现select跳转菜单新窗口效果代码分享(超简单)
2015/08/21 Javascript
直接拿来用的15个jQuery代码片段
2015/09/23 Javascript
javascript数组克隆简单实现方法
2015/12/16 Javascript
总结JavaScript三种数据存储方式之间的区别
2016/05/03 Javascript
AngularJS基础 ng-include 指令示例讲解
2016/08/01 Javascript
详解获取jq ul第一个li定位的四种解决方案
2016/11/23 Javascript
JS中检测数据类型的几种方式及优缺点小结
2016/12/12 Javascript
discuz表情的JS提取方法分析
2017/03/22 Javascript
使用vue-resource进行数据交互的实例
2017/09/02 Javascript
深入理解ES6 Promise 扩展always方法
2017/09/26 Javascript
快速搭建vue2.0+boostrap项目的方法
2018/04/09 Javascript
微信小程序实现滑动切换自定义页码的方法分析
2018/12/29 Javascript
this在vue和小程序中的使用详解
2019/01/28 Javascript
js 递归json树实现根据子id查父id的方法分析
2019/11/08 Javascript
Vue绑定用户接口实现代码示例
2020/11/04 Javascript
python快速查找算法应用实例
2014/09/26 Python
Python通过RabbitMQ服务器实现交换机功能的实例教程
2016/06/29 Python
Python 3.x 安装opencv+opencv_contrib的操作方法
2018/04/02 Python
python统计指定目录内文件的代码行数
2019/09/19 Python
Python实现LR1文法的完整实例代码
2020/10/25 Python
YSL圣罗兰美妆官方旗舰店:购买YSL口红
2018/04/16 全球购物
领班岗位职责范文
2014/02/06 职场文书
简历中自我评价怎么写
2014/02/12 职场文书
材料加工工程求职信
2014/02/19 职场文书
临床专业自荐信
2014/06/22 职场文书
领导班子作风建设剖析材料
2014/10/11 职场文书
《走遍天下书为侣》教学反思
2016/02/22 职场文书
javascript实现计算器功能详解流程
2021/11/01 Javascript
Python与C++中梯度方向直方图的实现
2022/03/17 Python