Python基础练习
1.两个变量的交换
# -*- coding: utf-8 -*-
# @Time : 2019/12/14 23:30
# @Author : 我就是任性-Amo
# @FileName: 1.两个变量的交换.py
# @Software: PyCharm
# @Blog :https://blog.csdn.net/xw1680
# 需求: 完成两个变量值的交换
# 如:a=20,b=30-->a=30,b=20
a = 20
b = 30
print(f"变量交换之前a的值为{a},b的值为{b}")
# 第一种交换变量的方式: 使用第三方临时变量
temp = a # 先将a值赋值给一个第三变量 存储a的值
a = b # 将b的值赋值给a
b = temp # 将temp的值赋值给b temp存储的值其实为原来变量a存储的值
print(f"变量交换之后a的值为{a},b的值为{b}")
# 第二种交换变量的方式: 使用python特有的方式
a, b = b, a
print(f"变量交换之后a的值为{a},b的值为{b}")
# 第三种交换变量的方式: 使用算术运算符的方式
# 总的来说: 无论a,b如何交换 他们的和都是不变的
a = a + b
b = a - b
a = a - b
print(f"变量交换之后a的值为{a},b的值为{b}")
# 第四种交换变量的方式: 使用位运算符的方式
a = a ^ b
b = a ^ b
a = a ^ b
print(f"变量交换之后a的值为{a},b的值为{b}")
# 在java中还可以使用下面这种方式:
# int a = 10;
# int b = 20;
# System.out.println("交换变量前a的值为:" + a + ",b的值为:" + b);
# a = (a + b) - (b = a);
# System.out.println("交换变量后a的值为:" + a + ",b的值为:" + b);
程序运行结果如下:
2.有四个数字:1、2、3、4,能组成多少个互不相同且无重复数字的三位数?各是多少?
# -*- coding: utf-8 -*-
# @Time : 2019/12/14 23:47
# @Author : 我就是任性-Amo
# @FileName: 2.数字1-4组成不同且不重复的三位数.py
# @Software: PyCharm
# @Blog :https://blog.csdn.net/xw1680
# 题目:有四个数字:1、2、3、4,能组成多少个互不相同且无重复数字的三位数?各是多少?
count = 0 # 计数器
for i in range(1, 5): # 百位的数字可以是1,2,3,4
for j in range(1, 5):
for k in range(1, 5):
# 百位 十位 个位的数字不重复
if i != j and i != k and j != k:
count += 1 # 符合条件计数器就+1
print(i * 100 + j * 10 + k) # 打印符合条件的三位数
print(count) # 打印符合条件的三位数的个数
程序运行结果如下:
3.求应发奖金数
# -*- coding: utf-8 -*-
# @Time : 2019/12/15 00:04
# @Author : 我就是任性-Amo
# @FileName: 3.求应发奖金数.py
# @Software: PyCharm
# @Blog :https://blog.csdn.net/xw1680
# 需求: 企业发放的奖金根据利润提成。从键盘输入当月利润I,求应发放奖金总数?
# 利润(i)低于或等于10万元时,奖金可提10%;
# 利润高于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可提成7.5%;
# 20万到40万之间时,高于20万元的部分,可提成5%;
# 40万到60万之间时高于40万元的部分,可提成3%;
# 60万到100万之间时,高于60万元的部分,可提成1.5%
# 高于100万元时,超过100万元的部分按1%提成
profit = [1000000, 600000, 400000, 200000, 100000, 0] # 利润
rate = [0.01, 0.015, 0.03, 0.05, 0.075, 0.1] # 利率
bonus = 0 # 奖金
# 键盘录入当月的利润i
i = int(input(">>>:"))
for j in range(6):
if i > profit[j]:
bonus += (i - profit[j]) * rate[j] # 减去基本数 再计算奖金
i = profit[j] # 下次计算的利润值
print(bonus)
程序运行结果如下:
4.输入某年某月某日,判断这一天是这一年的第几天?
# -*- coding: utf-8 -*-
# @Time : 2019/12/15 00:39
# @Author : 我就是任性-Amo
# @FileName: 4.判断用户输入的是这一年的第几天.py
# @Software: PyCharm
# @Blog :https://blog.csdn.net/xw1680
# 需求:输入某年某月某日,判断这一天是这一年的第几天?
# 思路:以5月20日为例,应该先把前四个月的加起来,然后再加上20天即本年的第几天
# 特殊情况就是: 如果年份为闰年且输入月份大于2时需考虑多加一天
year = int(input("年:"))
month = int(input("月:"))
day = int(input("日:"))
sum_day = 0 # 第几天
leap_year = 0 # 闰年
# 使用元组定义天数
# 如果输入的月份是1月份,则直接计算day即可
# 如果输入的月份是2月份,则要先计算出1月份的天数,即为31天
# 以此类推
# 1 2 3 4 5 6 7 8 9 10 11 12
# 0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334
months = (0, 31, 59, 90, 120, 151, 181, 212, 243, 273, 304, 334)
# 根据输入的月份,计算出前几个月的天数
if 0 < month <= 12:
sum_day = months[month - 1]
else:
print("输入的月份有误")
# 判断是否为闰年:
# 1.能被400整除 或者是 2.能被4整除并且不能被100整除
if year % 400 == 0 or (year % 4 == 0 and year % 100 != 0):
# 如果是闰年 则将leap_year变为1
leap_year = 1
# 判断如果是闰年并且输入的月份大于2则在总的天数上加1
if leap_year == 1 and month > 2:
sum_day += day + 1
else:
sum_day += day
print(f"it is the {sum_day}th day.") # 打印
程序运行结果如下:
5.输入三个整数x,y,z,请把这三个数由小到大输出
# -*- coding: utf-8 -*-
# @Time : 2019/12/15 01:06
# @Author : 我就是任性-Amo
# @FileName: 5.输入三个整数,由小到大输出.py
# @Software: PyCharm
# @Blog :https://blog.csdn.net/xw1680
# 题目:输入三个整数x,y,z,请把这三个数由小到大输出。
# 1.录入数据
x = int(input(">>>:"))
y = int(input(">>>:"))
z = int(input(">>>:"))
# 2.使用列表存储数据并进行排序
num_list = [x, y, z]
num_list.sort()
print(num_list)
程序运行结果如下:
6.斐波那契数列
# -*- coding: utf-8 -*-
# @Time : 2019/12/15 01:33
# @Author : 我就是任性-Amo
# @FileName: 6.斐波那契数列.py
# @Software: PyCharm
# @Blog :https://blog.csdn.net/xw1680
# 题目:斐波那契数列
# 程序分析: 斐波那契数列(Fibonacci sequence),又称黄金分割数列,指的是这样一个数列:
# 1 1 2 3 5 8 13 21 34 55....
# 第一种方式:使用函数
def fibonacci1(n):
a = 0
b = 1
for i in range(n):
a, b = b, a + b
print(f"斐波那契数列第{n}项的值为:{a}")
fibonacci1(3) # 2
# 第二种方式:使用递归
def fibonacci2(n):
if n == 1 or n == 2:
return 1
else:
return fibonacci2(n - 1) + fibonacci2(n - 2)
print(fibonacci2(10)) # 3
# 第三种方式:输出指定个数的斐波那契数列
def fibonacci3(n):
fibs = [1, 1]
if n == 1:
return [1]
if n == 2:
return [1, 1]
for i in range(2, n):
fibs.append(fibs[-1] + fibs[-2]) # 列表的最后两个数字相加
return fibs
print(fibonacci3(10))
# 第四种方式: 使用生成器的方式实现
def fibonacci4(n):
a = 0
b = 1
for i in range(0, n):
a, b = b, a + b
yield a
print("amo~")
f = fibonacci4(4)
print(f) # <generator object fibonacci4 at 0x101cc63d0>
print(next(f)) # 相当于去调用内置方法__next__ -->1
print(f.__next__()) # 1
print(f.__next__()) # 2
print(f.__next__()) # 3
程序运行结果如下:
7. 将一个列表的数据复制到另一个列表中
# -*- coding: utf-8 -*-
# @Time : 2019/12/15 02:15
# @Author : 我就是任性-Amo
# @FileName: 7.将一个列表的数据复制到另一个列表中.py
# @Software: PyCharm
# @Blog :https://blog.csdn.net/xw1680
list1 = [1, 2, 3, 4, 5]
print(list1)
# 1.直接使用列表的copy方法
new_list1 = list1.copy()
print(new_list1)
# 2.使用列表的切片
new_list2 = list1[:]
print(new_list2)
程序运行结果如下:
8.输出九九乘法表
# -*- coding: utf-8 -*-
# @Time : 2019/12/15 02:20
# @Author : 我就是任性-Amo
# @FileName: 8.输出 9*9 乘法口诀表.py
# @Software: PyCharm
# @Blog :https://blog.csdn.net/xw1680
# 分析: 九九乘法表的每一个小的单元类似为: 1 * 1 = 1
# print("1 * 1 = 1") # 只是里面的1随着行数在不停的变化 而等号后面的结果根据前面的数字动态生成
# print("2 * 1 = 2", end="\t")
# print("2 * 2 = 4")
# print("3 * 1 = 3", end="\t")
# print("3 * 2 = 6", end="\t")
# print("3 * 3 = 9")
# 综上: 发现规律第一个数字从1变化到9 第二个数字最多变化到和第一个数字相等 最后的数字为前两个数字的积
for i in range(1, 10): # 第一个数字的变化范围
for j in range(1, i + 1): # 第二个数字变化的范围
print(f"{i} * {j} = {i * j}", end="\t")
# 循环完成之后需要进行换行
print()
程序运行结果如下:
9.判断101-200之间有多少个素数,并输出所有素数
# -*- coding: utf-8 -*-
# @Time : 2019/12/15 10:32
# @Author : 我就是任性-Amo
# @FileName: 9.判断101-200之间有多少个素数,并输出所有素数.py
# @Software: PyCharm
# @Blog :https://blog.csdn.net/xw1680
# 题目: 判断101-200之间有多少个素数,并输出所有素数。
# 分析:
# 1.数据变化的范围是从101-200 所以需要使用循环
# 2.素数: 只能被1和本身整除的数 所以需要一个变量从1变到本身
# 3.判断: 如果有一个非1和本身的数被整除 则跳出循环 判断下一个数字
# 如果循环完成,都只有1和本身能被整除 说明符合条件 计数器+1
# 定义一个变量为计数器
count = 0
# 第一种方式: 使用while循环实现
i = 101
while i <= 200:
j = 2
# 其实这里的话是可以进行优化的 只需要判断数字的一半次数就可以了
# 因为数字就是等于两个数的乘积 判断了前一个数 后一个数肯定就不用判断了
# 数字的乘积就是一个小的数字*大的数字 减少循环的次数
# while j < i:
while j < i / 2:
if i % j == 0:
break
j += 1
else:
count += 1
print(i)
i += 1
print(f"The total is {count}")
count = 0
# 第二种方式: 使用for循环改写
for i in range(101, 201):
# for j in range(2, i):
for j in range(2, int(i / 2)): # 优化循环次数
if i % j == 0:
break
else:
count += 1
print(i)
print(f"The total is {count}")
程序运行结果如下:
10.打印水仙花数
# -*- coding: utf-8 -*-
# @Time : 2019/12/15 10:54
# @Author : 我就是任性-Amo
# @FileName: 10.打印水仙花数.py
# @Software: PyCharm
# @Blog :https://blog.csdn.net/xw1680
# 题目:打印出所有的"水仙花数",所谓"水仙花数"是指一个三位数,其各位数字立方和等于该数本身。
# 例如:153是一个"水仙花数",因为153=1的三次方+5的三次方+3的三次方
# 程序分析:利用for循环控制100-999个数,每个数分解出个位,十位,百位
# 核心: 就是如何获取到每个位上的数字
# 例子: 12345
# 个位: 12345 % 10
# 十位: 12345 // 10 % 10
# 百位: 12345 // 100 % 10
# 千位: 12345 // 1000 % 10
# 万位: 12345 // 10000
# 1.三位数的范围为:100~999 所以需要使用循环
for i in range(100, 1000):
# 2.根据水仙花数的概念去判断
ge_wei = i % 10
shi_wei = i // 10 % 10
bai_wei = i // 100
if i == (ge_wei ** 3 + shi_wei ** 3 + bai_wei ** 3):
print(i)
程序运行结果如下:
来源:CSDN
作者:Amo Xiang
链接:https://blog.csdn.net/xw1680/article/details/103546693