Python基础练习

天大地大妈咪最大 提交于 2019-12-15 12:12:30

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)

程序运行结果如下:
在这里插入图片描述

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!