#!/usr/bin/python
# -*- coding: utf-8 -*-
def z94():
#斐波那契数列
def filie(x):
a,b,t=1,1,0
if x==1 or x==2:return 1
while t!=x-2:
a,b,t=b,a+b,t+1
return b
for i in range(1,30):
print filie(i)
def z95():
#把三位数字转化成罗马数字
def lm(x):
fy=[["","C","CC","CCC","CD","D","DC","DCC","DCCC","CM"],
["","X","XX","XXX","XL","L","LX","LXX","LXXX","XCC"],
["","I","II","III","IV","V","VI","VII","VIII","IX"]]
e=reduce(lambda x,y:x+y,
map(lambda x,y:x[y],fy,map(lambda x:int(x),list(str(x)))))
print e
lm(863)
def z96():
#7个选手的得分分别是{5,3,4,7,3,5,6}序号是1~7,规则是得分越高,名次越低
#而相同的得分名次一样,输出名次是{3,1,2,5,1,3,4}
z=[5, 3, 4, 7, 3, 5, 6]
k=[0]*7
max1=0
minc=0
b=map(lambda x:list(x),zip(range(1,8),z,k))
b=sorted(b,cmp=lambda x,y: cmp(x[1], y[1]))
for i in b:
if i[1]>max1:
max1=i[1]
minc+=1
i[2]=minc
b=sorted(b)
t=map(lambda x:x[2],b)
print t
def z97():
#满足一定条件的序列:如3,2,2,1四数,他们的和是8,并且3>=2>=2>=1;找出所有这样的序列
n=18
r=[1]*4
num=1
for r[1] in range(r[0],n-sum(r[:0])):
for r[2] in range(r[1],n-sum(r[:1])):
for r[3] in range(r[2],n-sum(r[:2])):
t=n-sum(r)
if t>=r[3]:
tt=r[1:]+[t]
print num,tt
num+=1
return
def z97_b():
exec(zz97(23,6))
z97_a()
def zz97(n,k):
s='def z97_a():\n'
tb=' '
s+=tb+'n='+str(n+1)+'\n'
s+=tb+'r=[1]*'+str(k)+'\n'
g=lambda x:tb*(x)+'for r['+str(x)+'] in range(r['+str(x-1)+\
'],n-sum(r[:'+str(x-1)+'])):\n'
for i in range(1,k):
s+=g(i)
e=tb*(k+1)
s+=e+'t=n-sum(r)\n'+e+'if t>=r['+str(k-1)+']:\n'
e+=tb
s+=e+'tt=r[1:]+[t]\n'+e+'print tt'
print s
return s
def remo(x1,y):
mt=[]
for now in range(1,y+1):
t=True
for x in range(len(x1)):
m=x-len(x1)
if now==x1[x] or now==x1[x]+m or now==x1[x]-m:
t=False
if t:
mt+=[now]
return mt
def z98_4():
# 四皇后问题 ,就是把四个国际象棋里的皇后放到棋盘里问怎么放不互相吃
n=4
k=[1]*n
num=1
for k[0] in remo(k[:0],n):
for k[1] in remo(k[:1],n):
for k[2] in remo(k[:2],n):
for k[3] in remo(k[:3],n):
print num,k
num+=1
def zz98(n):
s='def z98_a():\n'
tb=' '
s+=tb+'n='+str(n)+'\n'
s+=tb+'k=[1]*n\n'
s+=tb+'num=1\n'
g=lambda x:tb*(x+1)+'for k['+str(x)+'] in remo(k[:'+str(x)+'],n):\n'
for i in range(0,n):
s+=g(i)
e=tb*(n+1)
s+=e+'print num,k\n'
s+=e+'num+=1\n'
print s
return s
def z98():
# 八皇后问题 ,就是把八个国际象棋里的皇后放到棋盘里问怎么放不互相吃
exec(zz98(8))
z98_a()
def z99():
#超长正整数的加法
a=122414354367l
b=23157465721578l
print a,"+",b,"=",a+b
class qi:
num0=1
st=''
def __init__(self, str1=None):
self.st=str1
self.num0=str1.find('')
return
def show(self):
st=list(self.st)
e=st[:]
e[7],e[8],e[5],e[4],e[3]=st[5],st[4],st[3],st[8],st[7]
m=0
for i in e:
m+=1
print i,
if m%3==0:print
return
def move(self,x):
st=list(self.st)
if st[x]!='':
st[x],st[self.num0]=st[self.num0],st[x]
return ''.join(st) def z100():
'''数字移动 ::在图上的九个点上,空出中间的点,其余的
点上任意填上1~8 8个数字,然后移动除了一之外其余的
数字,使1到8顺时针从小到大排列,规则是,只能将数字
沿线移动到空白的位置。'''
def nexts(d,e):
tt=[]
def add (a,b,t=tt,ee=e):
if a not in ee:
ee[a]=b
t+=[a]
return
for i in d:
x=qi(i)
if (x.num0==8):
for j in range(0,8):
add(x.move(j),i)
else:
t=x.num0
add(x.move((t+1)%8),i)
add(x.move((t+7)%8),i)
add(x.move(8),i)
return tt
s1 = ""
s3 = ""
i = len(s3)-s1.find("")
s3=s3[i:]+s3[:i]+''
a=qi(s1)
dd=[s1]
ee={s1:''}
while s3 not in ee:
dd=nexts (dd,ee)
e=ee[s3]
num=1
qi(s3).show()
num=1
print num
num+=1
while e!='':
qi(e).show()
print num
num+=1
e=ee[e]
return
if __name__ == '__main__':
s=""
for i in range(94,101):
s+='z'+str(i)+'()\n'
exec(s)

python 练习 3的更多相关文章

  1. Python中的多进程与多线程(一)

    一.背景 最近在Azkaban的测试工作中,需要在测试环境下模拟线上的调度场景进行稳定性测试.故而重操python旧业,通过python编写脚本来构造类似线上的调度场景.在脚本编写过程中,碰到这样一个 ...

  2. Python高手之路【六】python基础之字符串格式化

    Python的字符串格式化有两种方式: 百分号方式.format方式 百分号的方式相对来说比较老,而format方式则是比较先进的方式,企图替换古老的方式,目前两者并存.[PEP-3101] This ...

  3. Python 小而美的函数

    python提供了一些有趣且实用的函数,如any all zip,这些函数能够大幅简化我们得代码,可以更优雅的处理可迭代的对象,同时使用的时候也得注意一些情况   any any(iterable) ...

  4. JavaScript之父Brendan Eich,Clojure 创建者Rich Hickey,Python创建者Van Rossum等编程大牛对程序员的职业建议

    软件开发是现时很火的职业.据美国劳动局发布的一项统计数据显示,从2014年至2024年,美国就业市场对开发人员的需求量将增长17%,而这个增长率比起所有职业的平均需求量高出了7%.很多人年轻人会选择编 ...

  5. 可爱的豆子——使用Beans思想让Python代码更易维护

    title: 可爱的豆子--使用Beans思想让Python代码更易维护 toc: false comments: true date: 2016-06-19 21:43:33 tags: [Pyth ...

  6. 使用Python保存屏幕截图(不使用PIL)

    起因 在极客学院讲授<使用Python编写远程控制程序>的课程中,涉及到查看被控制电脑屏幕截图的功能. 如果使用PIL,这个需求只需要三行代码: from PIL import Image ...

  7. Python编码记录

    字节流和字符串 当使用Python定义一个字符串时,实际会存储一个字节串: "abc"--[97][98][99] python2.x默认会把所有的字符串当做ASCII码来对待,但 ...

  8. Apache执行Python脚本

    由于经常需要到服务器上执行些命令,有些命令懒得敲,就准备写点脚本直接浏览器调用就好了,比如这样: 因为线上有现成的Apache,就直接放它里面了,当然访问安全要设置,我似乎别的随笔里写了安全问题,这里 ...

  9. python开发编译器

    引言 最近刚刚用python写完了一个解析protobuf文件的简单编译器,深感ply实现词法分析和语法分析的简洁方便.乘着余热未过,头脑清醒,记下一点总结和心得,方便各位pythoner参考使用. ...

  10. 关于解决python线上问题的几种有效技术

    工作后好久没上博客园了,虽然不是很忙,但也没学生时代闲了.今天上博客园,发现好多的文章都是年终总结,想想是不是自己也应该总结下,不过现在还没想好,等想好了再写吧.今天写写自己在工作后用到的技术干货,争 ...

随机推荐

  1. java课堂动手动脑博客

    随机生成10个数,填充一个数组,然后用消息框显示数组内容,接着计算数组元素的和,将结果也显示在消息框中. 要求将设计思路.程序流程图.源程序代码.结果截图.编程总结等发表到博客园. (截止时间2015 ...

  2. ruby学习总结05

    1.数值类(Numeric) 有理数:Rational(分子,分母) 复数:Complex(实数,虚数) 随机数:Rnadom   rand()  返回比1小的浮点数,rand(种子数)  返回0到该 ...

  3. ASP.NET简单登录注册实例

    <%@ Page Language="C#" AutoEventWireup="true" CodeBehind="WebForm1.aspx. ...

  4. IP地址验证

    /** * 验证IP地址 * * @param 待验证的字符串 * @return 如果是符合格式的字符串,返回 <b>true </b>,否则为 <b>false ...

  5. JAVA排序--[冒泡排序]

    package com.array; public class Sort_MaoPao { /** * 项目名称:冒泡排序 * 项目要求:用JAVA对数组进行排序,并运用冒泡排序算法 * 作者:Sev ...

  6. RNAseq分析软件STAR的安装

    wget https://github.com/alexdobin/STAR/releases/STAR-2.5.2a.tar.gz tar -xzf STAR-2.5.2a.tar.gz cd ST ...

  7. poj 1106 Transmitters (叉乘的应用)

    http://poj.org/problem?id=1106 Time Limit: 1000MS   Memory Limit: 10000K Total Submissions: 4488   A ...

  8. Python语言精要---下

    函数: 可以返回多个值,其实函数是返回一个对象,就是元组,元组中的元素被拆分到各个结果变量中了 匿名函数: lambda函数,仅仅由单条语句组成,结果就是返回值 这种函数没有提供名称属性 闭包: cl ...

  9. XML约束——Schema约束

    XML Schema 也是一种用于定义和描述 XML 文档结构与内容的模式语言,其出现是为了克服 DTD 的局限性 XML Schema VS DTD: •XML Schema符合XML语法结构. • ...

  10. maven概念

     1. 下载并解压Maven:Maven下载页2. 将环境变量M2_HOME设置为解压后的目录: 3. 将M2环境变量设置为M2_HOME/bin(在Windows上是%M2_HOME%/bin,在U ...