【Python练习】编程基础

编程入门 行业动态 更新时间:2024-10-06 19:25:07

【Python练习】编程<a href=https://www.elefans.com/category/jswz/34/1770030.html style=基础"/>

【Python练习】编程基础

目录

实验目标

实验内容

1.绘制如下图形 ,一个正方形,内有三个红点,中间红点在正方形中心

2.使用turtle库绘制如下图形

3.绘制奥运五环图

4.回文问题

5.身份证性别判别

6.数据压缩

7.验证哥德巴赫猜想

8.使用蒙特 · 卡罗方法计算圆周率近似值问题

9.爬楼梯问题

10.年份判断 

11.选做题:汉诺塔问题

更多实验


实验目标

1.了解Python的基本编程环境,熟悉其主要组成部分和使用。

2.熟悉turtle库语法元素,了解其绘图坐标体系、画笔控制函数和运动命令函数。通过程序实例,初步掌握Python程序设计的基本概念、编程规则和开发过程。

3.掌握Python的基本数据类型的概念和使用;

4.运用Python的标准数学库进行数值计算;

5. 掌握字符串类型的格式化操作方法和应用。

6.熟练运用选择结构与循环结构解决实际问题。

实验内容

1.绘制如下图形 ,一个正方形,内有三个红点,中间红点在正方形中心

要求如下:

(1)正方形边长为200,线条为黑色;

(2)圆点的直径均为20 ,填充颜色为红色,画完后隐藏画笔;

(3)中间圆点的圆心位置为画布正中心,三个圆心之间距离相隔为40。                                            

程序设计 

import turtle as tu
tu.setup(width=1.0,height=1.0,startx=0,starty=0)
tu.bgcolor('white')
tu.pencolor('black')
tu.hideturtle()
tu.begin_fill()
tu.fillcolor('red')
tu.circle(10)
tu.end_fill()
tu.penup()
tu.goto(40,0)
tu.pendown()
tu.begin_fill()
tu.fillcolor('red')
tu.circle(10)
tu.end_fill()
tu.penup()
tu.goto(-40,0)
tu.pendown()
tu.begin_fill()
tu.fillcolor('red')
tu.circle(10)
tu.end_fill()
tu.penup()
tu.goto(-100,-100)
tu.pendown()
for i in range(4):tu.forward(200)tu.left(90)
tu.penup()
tu.goto(-20,200)
tu.pendown()
tu.mainloop()

2.使用turtle库绘制如下图形

(1)画一个由一个正方形和一个菱形组成的图形,其中,正方形的边长为200象素,菱形的四个顶点均在正方形四条边的中点上;

(2)设置画笔速度为1;

(3)菱形的填充颜色为红色,所有线条为黑色;

(4)画图结束,隐藏并停止画笔。

程序设计 

import turtle as tu
tu.hideturtle()
tu.setup(1.0,1.0,0,0)
tu.bgcolor('white')
tu.penup()
tu.goto(-100,-100)
tu.pendown()
for i in range(4):tu.forward(200)tu.left(90)
tu.penup()
tu.goto(0,-100)
tu.left(45)AC
tu.pendown()
tu.begin_fill()
tu.fillcolor("red")
for i in range(4):tu.forward(141)tu.left(90)
tu.end_fill()
tu.penup()
tu.goto(-20,200)
tu.pendown()
tu.mainloop()

3.绘制奥运五环图

其中五种颜色分别为蓝色、黑色、红色、黄色和绿色。注意根据实际效果调整圆形的大小和位置。

程序设计 

import turtle as tu
tu.setup(1.0,1.0,0,0)
tu.hideturtle()
tu.bgcolor('white')
tu.pencolor('black')
tu.pensize(5)
tu.circle(50)
tu.penup()
tu.goto(-120,0)
tu.pendown()
tu.pencolor('blue')
tu.pensize(5)
tu.circle(50)
tu.penup()
tu.goto(120,0)
tu.pendown()
tu.pencolor('red')
tu.pensize(5)
tu.circle(50)
tu.penup()
tu.goto(60,-60)
tu.pendown()
tu.pencolor('green')
tu.pensize(5)
tu.circle(50)
tu.penup()
tu.goto(-60,-60)
tu.pendown()
tu.pencolor('yellow')
tu.pensize(5)
tu.circle(50)
tu.penup()
tu.goto(-20,200)
tu.pendown()
tu.pencolor('black')
tu.mainloop()

4.回文问题

输入一个字符串,判断一个字符串是不是回文。

程序设计 

def f(s):for i in range(len(s)):if s[i]!=s[len(s)-i-1]:return Falsereturn True
print(f(input()))

5.身份证性别判别

输入一个18位字符组成的身份证号,其中第17位表示性别,如果是奇数表示男性,是偶数表示女性,编写代码实现判断输入的一个身份证号是男性还是女性。

程序设计 

def f(s):if int(s[16])%2==0:print('woman')else:print('man')
f(input())

6.数据压缩

用两个数据表示一段连续相同的字符,第一个数据记录指定字符重复相同的次数,第二个记录具体字符值。例如输入字符串“AAAABBBCC”,输出“4A3B2C”

程序设计 

def f(s):res=[]dic={}for i in s:if i in res:dic[i]+=1else:res.append(i)dic[i]=1for i in res:print("%d%s"%(dic[i],i),end='')
f("AAAABBBCC")

7.验证哥德巴赫猜想

任何大于2的偶数,都可以表示为两个素数之和。输入一个大于2的偶数,若猜想成功屏幕上输出哥德巴赫猜想等式,否则输出“Failed”。

例如:输入100,输出97+3。

程序设计 

def su(n):for i in range(2,n//2+1):if n%i==0:return Falsereturn True
def f(n):for i in range(2,n//2+1):if su(i) and su(n-i):print(("%d+%d")%(n-i,i))returnprint('Failed')return 
f(100)

8.使用蒙特 · 卡罗方法计算圆周率近似值问题

试着编写程序,模拟蒙特·卡罗计算圆周率近似值的方法,输入掷飞镖次数,然后输出圆周率近似值。

蒙特·卡罗方法是一种通过概率来得到问题近似解的方法,在很多领域都有重要的应用,其中就包括圆周率近似值的计算问题。假设有一块边长为 2 的正方形木板,上面画一个单位圆,然后随意往木板上扔飞镖,落点坐标(x, y)必然在木板上(更多的时候是落在单位圆内),如果扔的次数足够多,那么落在单位圆内的次数除以总次数再乘以 4,这个数字会无限逼近圆周率的值。

提示:random模块用法

import random #导入random模块

random.random()产生0-1之间的一个随机数

程序设计 

import random as r
n=1000000
sums=0
for i in range(n):x=r.uniform(0,1)y=r.uniform(0,1)if (x-0.5)*(x-0.5)+(y-0.5)*(y-0.5)<=0.25:sums+=1
print(sums/n*4)

9.爬楼梯问题

假设一段楼梯共 15 个台阶,小明一步最多能上 3 个台阶。输入小明上的台阶,计算小明上这段楼梯一共有多少种方法。从第15个台阶上往回看,有3种方法可以上来(从第14个台阶上一步迈1个台阶上来,从第13个台阶上一步迈2个台阶上来,从第12个台阶上一步迈3个台阶上来),同理,第14个、13个、12个台阶都可以这样推算,从而得到公式f(n) = f(n-1) + f(n-2) + f(n-3),其中n=15、14、13、...、5、4。然后确定这个递归公式的结束条件了,第一个台阶只有1种上法,第二个台阶有2种上法(一步迈2个台阶上去、一步迈1个台阶分两步上去),第三个台阶有4种上法,….

程序设计 

def f(n):if n<0:return 0if n==0:return 1return weimeng(n-1)+weimeng(n-2)+weimeng(n-3)
print(f(15))

10.年份判断 

输入某一个年份,输出该年份开始的12个年份及对应的天干地支与生肖。例如:

输入:2009年

输出:

2009 己丑 牛

...【中间部分省略了,程序测试效果要输出】

2020 庚子 鼠

程序设计 

year = int(input("请输入年份:"))
tiangan = ['甲', '乙', '丙', '丁', '戊', '己', '庚', '辛', '壬', '癸']
dizhi = ['子', '丑', '寅', '卯', '辰', '巳', '午', '未', '申', '酉', '戌', '亥']
shengxiao = ['鼠', '牛', '虎', '兔', '龙', '蛇', '马', '羊', '猴', '鸡', '狗', '猪']
gan = tiangan[(year - 4)%10]
zhi = dizhi[(year - 4)%12]
xiao = shengxiao[(year - 4)%12]
for i in range(year, year + 12):gan = tiangan[(i - 4)%10]zhi = dizhi[(i - 4)%12]xiao = shengxiao[(i - 4)%12]print(i, gan, zhi, xiao)

11.选做题:汉诺塔问题

据说古代有一个梵塔,塔内有三个底座 A、B、C,A 座上有 64 个盘子,盘子大小不等,大的在下,小的在上。有一个和尚想把这 64 个盘子从 A 座移到 C 座,但每次只能允许移动一个盘子。在移动盘子的过程中可以利用 B 座,但任何时刻 3 个座上的盘子都必须始终保持大盘在下、小盘在上的顺序。如果只有一个盘子,则不需要利用 B 座,直接将盘子从 A 移动到 C 即可。编写函数,接收一个表示盘子数量的参数和分别表示源、目标、临时底座的参数,然后输出详细移动步骤和每次移动后三个底座上的盘子分布情况。

程序设计 

t=1
def f(n,a,b,c):global tif n==1:print("%d.Move %d from %s to %s"%(t,n,a,c))t+=1return Nonef(n-1,a,c,b)print("%d.Move %d from %s to %s"%(t,n,a,c))t+=1f(n-1,b,a,c)
n=int(input())
a,b,c='a','b','c'
f(n,a,b,c)

更多实验

序号文章目录直达链接
1编程基础
2序列结构
3函数与库
4正则表达式
5面向对象编程
6数值计算库Numpy
7数据分析库Pandas
8Matplotlib数据可视化
9有关素数的问题
10蒙特卡罗方法求解定积分

更多推荐

【Python练习】编程基础

本文发布于:2024-02-28 14:53:07,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1769788.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:基础   Python

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!