当前位置: 首页 > news >正文

实验一 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)

http://www.lryc.cn/news/29194.html

相关文章:

  • java多线程(十五)ThreadLocal介绍和理解
  • K8S 实用工具之三 - 图形化 UI Lens
  • HDMI协议介绍(六)--EDID
  • 【项目实战】Linux下安装Nginx教程
  • 【数据结构】链式二叉树
  • CentOS安装RStudio-Server的方法
  • 从交通信号灯看流控和拥塞控制
  • 【LinkedList】| 深度剥析Java SE 源码合集Ⅰ
  • 黑马程序员7
  • Qt安装与使用经验分享;无.pro文件;无QTextCodec file;Qt小试;界面居中;无缝;更换Qt图标;更换Qt标题。
  • AAAI顶会行人重识别算法详解——Relation Network for Person Re-identification
  • hadoop调优(二)
  • 【基础算法】双指针---数组元素的目标和
  • Javascript借用原型对象继承父类型方法
  • 你不会工作1年了连枚举都还不知道吧?
  • ks通过恶意低绩效来变相裁员(五)绩效申诉就是「小六自证吃了一碗凉粉」
  • 一阶低通滤波介绍及simulink模型
  • 三十三、MongoDB PHP 扩展
  • 2D图像处理:九点标定_上(机械手轴线与法兰轴线重合)(附源码)
  • 2023最新C++面经(一):vector内存预分配,左值引用和右值引用,move语义
  • 【C语言经典例题】调整数组使奇数全部都位于偶数前面
  • C++经典20题型,满满知识,看这一篇就够了(含答案)
  • 卷积神经网络CNN之ZF Net网络模型详解(理论篇)
  • Vue 3.0 响应性 基础 【Vue3 从零开始】
  • flex布局方式让最后一个(或第二个...n)元素居右显示
  • 【Python语言基础】——Python MySQL Order By
  • 自然数学的哲学原理--复数理论的扩展
  • tsconfig.json中的一些配置
  • Spark调优总结
  • 4.创建和加入通道相关(network.sh脚本createChannel函数分析)[fabric2.2]