python 练习 4
#!/usr/bin/python
# -*- coding: utf-8 -*-
from math import sqrt
import random
def daoxu(n):
d=n
s=0
while d!=0:
d,f=divmod(d,10)
s=f+s*10
return s
def z85():
#任意取一个十进制数如123,然后他和他的回文数321相加,得到新整数后重复以上步骤,最后
#可以得到一个回文数444
s1=179233126
s2=0
while s2!=s1:
s1=s1+s2
s2=daoxu(s1)
print s2
return
def z81():
'''角谷猜想是任何一个数如果是偶数就除以2如果是奇数就乘以3再加1,最后会导致1,4,2,循环'''
x=123347
while x!=1:
x= x%2==0 and x/2 or (x*3+1)/2
print x
def fangf(x):
t=int(sqrt(x))
if t*t==x: return [t]
t=int(sqrt(x-1))+1
m=range(t)
for i in m:
for j in m:
for k in range(j,t):
for p in range(k,t):
if i *i + j * j + k * k + p * p == x:
if i==0 and j==0:return[k,p]
if i==0 and j!=0:return[j,k,p]
return [i,j,k,p]
def z82():
#所有自然数最多可以用四个自然数的平方表示,验证这个定理
for i in range(2,100):
print i,fangf(i)
def z83():
# 任意一个四位数,如1324,可以得到数1234和4321,然后4321-1234得到新数,重复以上步骤,
#最后得到6174。而7641-1467=6174
def six(x):
t=1
e=list(str(x))
e.sort()
e=''.join(e)
n=int(e)
if n<1000:t=10
return daoxu(n)*t-n
i=1999
print i
while i!=6174:
i=six(i)
print i
def z84():
'''证明任何一个数a的立方等于一串连续奇数的和,其中首项为(a*(a-1)+1),公差为2,共a项
他们的和是((a*(a-1)+1)*a+(2*a-2)*a/2=(a^3-a^2+a)+(a^2-a)=a^3
'''
print "任何一个数a的立方等于一串连续奇数的和"
return
def z80():
'''很容易证明的定理大于1000的奇数x有x*x-1是8的倍数
[1,3,5,7]=[1,1,1,1]
'''
t=[i*i%8 for i in range(1,8,2)]
print t
print "大于1000的奇数x有x*x-1是8的倍数"
return
def z78():
#用正多边形逼近的方法计算pi
x1=100000
b,i=0.5,6
while i<x1:
b=sqrt(2-2*sqrt(1-b*b))/2
i*=2
print b*i
def z79():
'''随机法计算pi:
本程序并不使用计算pi值的算法,它只是一个概
率模拟,即在边长为100的正方形内随机产生多
个点,将点以圆弧为界分开统计,由于点的个数
很多,直至几乎布满整个区域。此时,点的个数
就可以看作就是它所在区域的面积。可以得到如
下推导: (1)蓝色区内点个数:总个数≈蓝色面积:总面积 (2)蓝色区内点个数:总个数≈圆面积/4:总面积 (3)蓝色区内点个数:总个数≈π×200×200/4:200×200 (4)π≈ 4×蓝色区内点个数/总个数 当然,点的位置会重复,所以结果与π值是
有差别的,不过,当点足够多时,可以看到一个
非常接近的结果。'''
x,y,z=0,100000,0
g=random.random
while x<y:
a=g()
b=g()
if a*a+b*b<1:
z+=1
x+=1
print 4.0*z/y
if __name__ == '__main__':
s=""
for i in range(78,86):
s+='z'+str(i)+'()\n'
exec(s)
python 练习 4的更多相关文章
- Python中的多进程与多线程(一)
一.背景 最近在Azkaban的测试工作中,需要在测试环境下模拟线上的调度场景进行稳定性测试.故而重操python旧业,通过python编写脚本来构造类似线上的调度场景.在脚本编写过程中,碰到这样一个 ...
- Python高手之路【六】python基础之字符串格式化
Python的字符串格式化有两种方式: 百分号方式.format方式 百分号的方式相对来说比较老,而format方式则是比较先进的方式,企图替换古老的方式,目前两者并存.[PEP-3101] This ...
- Python 小而美的函数
python提供了一些有趣且实用的函数,如any all zip,这些函数能够大幅简化我们得代码,可以更优雅的处理可迭代的对象,同时使用的时候也得注意一些情况 any any(iterable) ...
- JavaScript之父Brendan Eich,Clojure 创建者Rich Hickey,Python创建者Van Rossum等编程大牛对程序员的职业建议
软件开发是现时很火的职业.据美国劳动局发布的一项统计数据显示,从2014年至2024年,美国就业市场对开发人员的需求量将增长17%,而这个增长率比起所有职业的平均需求量高出了7%.很多人年轻人会选择编 ...
- 可爱的豆子——使用Beans思想让Python代码更易维护
title: 可爱的豆子--使用Beans思想让Python代码更易维护 toc: false comments: true date: 2016-06-19 21:43:33 tags: [Pyth ...
- 使用Python保存屏幕截图(不使用PIL)
起因 在极客学院讲授<使用Python编写远程控制程序>的课程中,涉及到查看被控制电脑屏幕截图的功能. 如果使用PIL,这个需求只需要三行代码: from PIL import Image ...
- Python编码记录
字节流和字符串 当使用Python定义一个字符串时,实际会存储一个字节串: "abc"--[97][98][99] python2.x默认会把所有的字符串当做ASCII码来对待,但 ...
- Apache执行Python脚本
由于经常需要到服务器上执行些命令,有些命令懒得敲,就准备写点脚本直接浏览器调用就好了,比如这样: 因为线上有现成的Apache,就直接放它里面了,当然访问安全要设置,我似乎别的随笔里写了安全问题,这里 ...
- python开发编译器
引言 最近刚刚用python写完了一个解析protobuf文件的简单编译器,深感ply实现词法分析和语法分析的简洁方便.乘着余热未过,头脑清醒,记下一点总结和心得,方便各位pythoner参考使用. ...
- 关于解决python线上问题的几种有效技术
工作后好久没上博客园了,虽然不是很忙,但也没学生时代闲了.今天上博客园,发现好多的文章都是年终总结,想想是不是自己也应该总结下,不过现在还没想好,等想好了再写吧.今天写写自己在工作后用到的技术干货,争 ...
随机推荐
- word2007
word2007 word2007图标 word2007边框和底纹 word2007扫描图片 word2007剪贴画 word2007图片 word2007页面视图 w ...
- <转>离婚前夜悟出的三件事
文/铁眼(简书作者)原文链接:http://www.jianshu.com/p/832be4f659a0?utm_campaign=hugo&utm_medium=reader_share&a ...
- Cheatsheet: 2014 04.01 ~ 04.30
Java 115 Java Interview Questions and Answers – The ULTIMATE List 3 Good Reasons to Avoid Arrays in ...
- 粒子群优化算法(Particle Swarm Optimization)
粒子群算法的思想源于对鸟/鱼群捕食行为的研究,模拟鸟集群飞行觅食的行为,鸟之间通过集体的协作使群体达到最优目的,是一种基于Swarm Intelligence的优化方法.它没有遗传算法的"交 ...
- python_way day13 sqlalchemy
sqlalchemy 一对多 多对多 1.一对多 一.#创建表结构 class Host(Base): #所有的子类都继承这个基类 #创建表结构 __tablename__ = 'hosts' id ...
- lazyload懒加载的使用
1.引用<script src="http://a.tbcdn.cn/apps/baron/js/??lib/tmm/tmm.js,lib/lazyload/lazyload.js?2 ...
- 整理的一些常用的CSS HACK
ie8以下兼容透明都和支持CSS圆角,这两个都要在服务器上才看到效果,可以本地搭建一个服务器如IIS -pie-background: rgba(255, 255, 255, 0.10);/*IE6 ...
- [转载] Linux下查看内存使用情况方法总结
原文: http://9iphp.com/linux/1247.html 强烈推荐 htop.
- Codeforces 713D Animals and Puzzle
题意:一个n*m的01矩阵,Q个询问,每次询问一个矩形区域内,最大的全1正方形的边长是多少? 题解:dp[0][0][i][j]表示以(i, j)为右下角的正方形的最长边长.RMQ后,二分答案即可. ...
- 卷积FFT、NTT、FWT
先简短几句话说说FFT.... 多项式可用系数和点值表示,n个点可确定一个次数小于n的多项式. 多项式乘积为 f(x)*g(x),显然若已知f(x), g(x)的点值,O(n)可求得多项式乘积的点值. ...