《Python程序设计》

python编程题

  1. 给定一个年份,判断这一年是不是闰年。

def is_leap_year(year): 

    if year % 4 != 0: 

        return False 

    elif year % 100 != 0: 

        return True 

    elif year % 400 != 0: 

        return False 

    else: 

        return True 

 

# 测试函数 

year = int(input("请输入一个年份: ")) 

if is_leap_year(year): 

    print(f"{year} 是闰年") 

else: 

    print(f"{year} 不是闰年")

  1. 平面上有两个矩形,它们的边平行于直角坐标系的X轴或Y轴。对于每个矩形,我们给出它的一对相对顶点的坐标,请你编程算出两个矩形的交的面积。 输入格式   输入仅包含两行,每行描述一个矩形。   在每行中,给出矩形的一对相对顶点的坐标,每个点的坐标都用两个绝对值不超过10^7的实数表示。 输出格式   输出仅包含一个实数,为交的面积,保留到小数后两位。

def calculate_intersection_area(rect1, rect2): 

    # 提取矩形的坐标 

    x1, y1, x2, y2 = rect1 

    x3, y3, x4, y4 = rect2 

 

    # 计算交集的坐标 

    # 交集在x轴上的范围 

    x_start = max(x1, x3) 

    x_end = min(x2, x4) 

    # 交集在y轴上的范围 

    y_start = max(y1, y3) 

    y_end = min(y2, y4) 

 

    # 检查是否有交集 

    if x_start < x_end and y_start < y_end: 

        # 计算交集面积 

        intersection_area = (x_end - x_start) * (y_end - y_start) 

        return round(intersection_area, 2) 

    else: 

        # 没有交集 

        return 0.0 

 

# 读取输入 

rect1_input = input().split() 

rect1 = (float(rect1_input[0]), float(rect1_input[1]), float(rect1_input[2]), float(rect1_input[3])) 

 

rect2_input = input().split() 

rect2 = (float(rect2_input[0]), float(rect2_input[1]), float(rect2_input[2]), float(rect2_input[3])) 

 

# 计算并输出交集面积 

intersection_area = calculate_intersection_area(rect1, rect2) 

print(intersection_area)

  1. 给定一个n*n的棋盘,棋盘中有一些位置不能放皇后。现在要向棋盘中放入n个黑皇后和n个白皇后,使任意的两个黑皇后都不在同一行、同一列或同一条对角线上,任意的两个白皇后都不在同一行、同一列或同一条对角线上。问总共有多少种放法?n小于等于8。

def solveNQueens(n): 

    # 初始化棋盘 

    board = [['.' for _ in range(n)] for _ in range(n)] 

    # 记录每行、每列和两个对角线上是否有皇后的集合 

    rows, cols, diag1, diag2 = set(), set(), set(), set() 

    # 记录不能放置皇后的位置 

    forbidden = set() 

    # 记录黑皇后和白皇后的数量 

    black_queens, white_queens = 0, 0 

 

    def can_place(row, col): 

        # 检查是否有皇后在同一行、同一列或对角线上 

        return ( 

            row not in rows and 

            col not in cols and 

            row - col not in diag1 and 

            row + col not in diag2 

        ) 

 

    def place_queen(row, color): 

        nonlocal black_queens, white_queens 

        # 尝试在当前行的每一列放置皇后 

        for col in range(n): 

            if (row, col) not in forbidden and can_place(row, col): 

                # 标记该位置有皇后 

                board[row][col] = 'B' if color == 'black' else 'W' 

                rows.add(row) 

                cols.add(col) 

                diag1.add(row - col) 

                diag2.add(row + col) 

                 

                # 递归放置下一个皇后 

                if color == 'black': 

                    if row < n - 1: 

                        place_queen(row + 1, 'black') 

                    else: 

                        black_queens += 1 

                        place_queen(0, 'white') 

                else: 

                    if row < n - 1: 

                        place_queen(row + 1, 'white') 

                    else: 

                        white_queens += 1 

                        # 如果所有皇后都放置完毕,则增加总方案数 

                        if black_queens == n and white_queens == n: 

                            nonlocal total_solutions 

                            total_solutions += 1 

 

                # 回溯,撤销放置皇后的操作 

                board[row][col] = '.' 

                rows.remove(row) 

                cols.remove(col) 

                diag1.remove(row - col) 

                diag2.remove(row + col) 

 

    # 记录总方案数 

    total_solutions = 0 

    # 开始放置黑皇后 

    place_queen(0, 'black') 

     

    # 返回总方案数 

    return total_solutions 

 

# 测试代码 

n = 4  # 更改 n 的值来测试不同的棋盘大小 

print(f"Total solutions for {n}x{n} board: {solveNQueens(n)}")

  1. 某公司有一台打印机,需要将购买成本分年均摊到隔年的费用中。请编写一个程序,根据用户输入的购买金额和预计使用年限计算每年的分摊费用。要求对输入异常进行适当的处理(输入错误、被零除)。另外,当计算得到每年的分摊费用大于100时,抛出InvalidNumberError,并进行处理。
  2. 给定两个仅由大写字母或小写字母组成的字符串(长度介于1到10之间),它们之间的关系是以下4种情况之一:

1:两个字符串长度不等。比如 Beijing 和 Hebei

2:两个字符串不仅长度相等,而且相应位置上的字符完全一致(区分大小写),比如 Beijing 和 Beijing

3:两个字符串长度相等,相应位置上的字符仅在不区分大小写的前提下才能达到完全一致(也就是说,它并不满足情况2)。比如 beijing 和 BEIjing

4:两个字符串长度相等,但是即使是不区分大小写也不能使这两个字符串一致。比如 Beijing 和 Nanjing

def compare_strings(s1, s2): 

    # 检查两个字符串长度是否相等 

    if len(s1) != len(s2): 

        return "两个字符串长度不等" 

     

    # 检查两个字符串是否完全相同(区分大小写) 

    if s1 == s2: 

        return "两个字符串不仅长度相等,而且相应位置上的字符完全一致" 

     

    # 检查两个字符串是否在不区分大小写的情况下相同 

    if s1.lower() == s2.lower(): 

        return "两个字符串长度相等,相应位置上的字符仅在不区分大小写的前提下才能达到完全一致" 

     

    # 如果以上条件都不满足,则它们既不相同也不满足不区分大小写的相同 

    return "两个字符串长度相等,但是即使是不区分大小写也不能使这两个字符串一致"

print(compare_strings(str1, str2))

  1. 话说这个世界上有各种各样的兔子和乌龟,但是研究发现,所有的兔子和乌龟都有一个共同的特点——喜欢赛跑。 于是世界上各个角落都不断在发生着乌龟和兔子的比赛,小华对此很感兴趣,于是决定研究不同兔子和乌龟的赛跑。 他发现,兔子虽然跑比乌龟快,但它们有众所周知的毛病——骄傲且懒惰,于是在与乌龟的比赛中,一旦任一秒结束后兔子发现自己领先t米或以上,它们就会停下来休息s秒。对于不同的兔子,t,s的数值是不同的,但是所有的乌龟却是一致——它们不到终点决不停止。 然而有些比赛相当漫长,全程观看会耗费大量时间,而小华发现只要在每场比赛开始后记录下兔子和乌龟的数据——兔子的速度v1(表示每秒兔子能跑v1米), 乌龟的速度v2,以及兔子对应的t,s值,以及赛道的长度l——就能预测出比赛的结果。但是小华很懒, 不想通过手工计算推测出比赛的结果,于是他找到了你——清华大学计算机系的高才生——请求帮助,请你写一个程序, 对于输入的一场比赛的数据v1,v2,t,s,l,预测该场比赛的结果。

程序的基本逻辑:

初始化兔子和乌龟的位置为0。

每一秒,更新兔子和乌龟的位置。

检查兔子是否领先乌龟t米或以上,如果是,则兔子休息s秒。

当任何一个参赛者到达终点时,停止模拟并输出比赛结果。

def race_simulation(v1, v2, t, s, l): 

    rabbit_position = 0  # 兔子的位置 

    tortoise_position = 0  # 乌龟的位置 

    time_elapsed = 0  # 经过的时间 

    rabbit_resting = False  # 兔子是否在休息  

 

    while True: 

        # 如果兔子没有在休息,则更新兔子的位置 

        if not rabbit_resting: 

            rabbit_position += v1 

 

        # 更新乌龟的位置 

        tortoise_position += v2 

 

        # 检查兔子是否领先乌龟t米或以上,如果是,则兔子开始休息 

        if rabbit_position - tortoise_position >= t and not rabbit_resting: 

            rabbit_resting = True 

            print(f"兔子在第{time_elapsed+1}秒领先乌龟{t}米以上,开始休息{s}秒") 

             

        # 如果兔子已经休息完s秒,则兔子继续赛跑 

        if rabbit_resting and time_elapsed % s == s - 1: 

            rabbit_resting = False 

 

        # 检查是否有参赛者到达终点 

        if rabbit_position >= l: 

            return "兔子获胜" 

        elif tortoise_position >= l: 

            return "乌龟获胜" 

 

        # 增加时间 

        time_elapsed += 1 

 

# 调用函数并打印结果 

result = race_simulation(v1, v2, t, s, l) 

print(f"比赛结果为:{result}")

  1. 实现用户输入用户名和密码,当用户名为 admin且 密码为 123 时,显示登陆成功,否则登陆失败!

# 用户预设的用户名和密码 

preset_username = "admin" 

preset_password = "123" 

 

# 获取用户输入的用户名和密码 

username = input("请输入用户名: ") 

password = input("请输入密码: ") 

 

# 检查用户名和密码是否匹配预设值 

if username == preset_username and password == preset_password: 

    print("登陆成功") 

el

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/25327.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

使用python绘制季节图

使用python绘制季节图 季节图效果代码 季节图 季节图&#xff08;Seasonal Plot&#xff09;是一种数据可视化图表&#xff0c;用于展示时间序列数据的季节性变化。它通过将每个时间段&#xff08;如每个月、每个季度&#xff09;的数据绘制在同一张图表上&#xff0c;使得不同…

移动安全赋能化工能源行业智慧转型

随着我国能源化工企业的不断发展&#xff0c;化工厂中经常存在火灾爆炸的危险&#xff0c;特别是生产场所&#xff0c;约有80%以上生产场所区域存在爆炸性物质。而目前我国化工危险场所移动通信设备的普及率高&#xff0c;但是对移动通信设备的安全防护却有所忽视&#xff0c;包…

c++11 lambda匿名函数

概述: 匿名函数: 就是一个没有名字的函数&#xff0c;和匿名对象类似&#xff0c;其只会在所在行起作用。那么lambda匿名函数的主要用处是什么呢&#xff1f; 举个例子: 我们之前使用过sort()排序函数&#xff0c;其可以根据你传入的一组数据&#xff0c;根据某种规则进行排…

关系数据库标准查询语言-SQL-SQL语言概述

一、SQL(Structured Query Language)语言 1、是高度非过程化的语言 2、关系数据库管理系统(RDBMS)都支持SQL标准 3、具有定义、查询、更新、控制四大功能 4、数据库对象由数据库&#xff08;Database&#xff09;、基本表&#xff08;Table&#xff09;、视图&#xff08;V…

python-doipclient 源文档翻译

python-doipclient 源文档翻译 doipclient 是一个纯 Python 3 的诊断通过互联网&#xff08;DoIP&#xff09;客户端库&#xff0c;可用于通过汽车以太网与现代电子控制单元&#xff08;ECUs&#xff09;通信。它从短期同步客户端的角度实现了 ISO-13400&#xff08;2019 年版…

string经典题目(C++)

文章目录 前言一、最长回文子串1.题目解析2.算法原理3.代码编写 二、字符串相乘1.题目解析2.算法原理3.代码编写 总结 前言 一、最长回文子串 1.题目解析 给你一个字符串 s&#xff0c;找到 s 中最长的回文子串。 示例 1&#xff1a; 输入&#xff1a;s “babad” 输出&am…

Yocto - 变量介绍:BASE_WORKDIR、WORKDIR和D

BASE_WORKDIR 指向所有配方的工作目录根目录。默认值为"${TMPDIR}/work"。 Points to the base of the work directory for all recipes. The default value is “${TMPDIR}/work”. $ bitbake -e <recipe-name>| grep ^BASE_WORKDIR BASE_WORKDIR"/home…

自动化测试-Selenium-元素定位

一.元素定位 因为使用selenium进行自动化测试&#xff0c;元素定位是必不可少的&#xff0c;所以这篇文章用于自动化测试中的selenium中的元素定位法。 1.根据id属性进行定位&#xff08;id是唯一的&#xff09; id定位要求比较高&#xff0c;要求这个元素的id必须是固定且唯…

方差的计算(总体方差与样本方差)

方差是数据集中的各个数据与其均值之间差值的平方的平均值。方差的计算公式如下&#xff1a; 对于总体数据&#xff08;即所有数据&#xff09;&#xff1a; σ 2 1 N ∑ i 1 N ( x i − μ ) 2 \sigma^2 \frac{1}{N} \sum_{i1}^N (x_i - \mu)^2 σ2N1​i1∑N​(xi​−μ)2…

Java的自动装箱和自动拆箱

自动装箱和拆箱在Java开发中的应用与注意事项 在Java开发中&#xff0c;自动装箱&#xff08;Autoboxing&#xff09;和自动拆箱&#xff08;Unboxing&#xff09;是指基本数据类型与其对应的包装类之间的自动转换。这些特性可以使代码更加简洁和易读&#xff0c;但在实际项目…

CANoe-Trace窗口无法解析SOME/IP报文、Demo License激活方式改变

1、Trace窗口无法解析SOME/IP报文 在文章《如何让CANoe或Wireshark自动解析应用层协议》中,我们通过设置指定端口号为SOME/IP报文的方式,可以让CANoe中的Trace窗口对此端口号的报文当成是SOME/IP报文进行解析。 Trace窗口就可以根据传输层端口号对payload数据按照SOME/IP协议…

linuxDNS域名解析

文章目录 DNS 是域名系统的简称正向解析反向解析主从服务器解析bond网卡 DNS 是域名系统的简称 域名和IP地址之间的映射关系 互联网中&#xff0c;IP地址是通信的唯一标识&#xff0c;逻辑地址 访问网站 域名解析的目的就是为了实现&#xff0c;访问域名就等于访问IP地址 …

JS(JavaScript)的引用方式介绍与代码演示

天行健&#xff0c;君子以自强不息&#xff1b;地势坤&#xff0c;君子以厚德载物。 每个人都有惰性&#xff0c;但不断学习是好好生活的根本&#xff0c;共勉&#xff01; 文章均为学习整理笔记&#xff0c;分享记录为主&#xff0c;如有错误请指正&#xff0c;共同学习进步。…

CSS:字数超出容器范围,超出部分省略,变成...

用CSS实现文本超出/溢出容器范围时&#xff0c;超出的部分省略&#xff0c;展示… &#xff08;针对block元素&#xff0c;如果是span&#xff0c;需要添加display&#xff1a;block&#xff1b;&#xff09; 单行文本&#xff1a; .overText{white-space: nowrap;overflow:…

中国同胞进来看看,很多外国人想通过CSDN坑咱们中国人

地址&#xff1a;【诈骗离你我很近】中国同胞进来看看国外诈骗新套路。-CSDN博客

SpringBoot+Vue体育馆管理系统(前后端分离)

技术栈 JavaSpringBootMavenMySQLMyBatisVueShiroElement-UI 角色对应功能 学生管理员 功能截图

Linux安装MySQL教程【带图文命令巨详细】

巨详细Linux安装MySQL 1、查看是否有自带数据库或残留数据库信息1.1检查残留mysql1.2检查并删除残留mysql依赖1.3检查是否自带mariadb库 2、下载所需MySQL版本&#xff0c;上传至系统指定位置2.1创建目录2.2下载MySQL压缩包 3、安装MySQL3.1创建目录3.2解压mysql压缩包3.3安装解…

对硬盘的设想2:纸存,硬指针,软指针

“纸存”是设想中的存储器&#xff0c;它只能改写两次&#xff1a;写一次&#xff0c;再改一次&#xff0c;然后就不能再动了。就像拿着钢笔在纸上写字一样&#xff0c;所以叫纸存。 硬指针P、软指针S S abcd S aPcdPx P aPcdPx S aycd ①一个软指针S&#xff0c;指向数据abcd…

DBeaver无法连接Clickhouse,连接失败

DBeaver默认下载的是0.2.6版本的驱动&#xff0c;但是一直连接失败&#xff1a; 报错提示 解决办法 点击上图中的Open Driver Configuration点击库 - 重置为默认状态在弹出的窗口中修改驱动版本号为0.2.4或者其他版本&#xff08;我没有试用过其他版本&#xff09;&#xff0…

vscode软件上安装 Fitten Code插件及使用

一. 简介 前面几篇文章学习了 Pycharm开发工具上安装 Fitten Code插件&#xff0c;以及 Fitten Code插件的使用。 Fitten Code插件是是一款由非十大模型驱动的 AI 编程助手&#xff0c;它可以自动生成代码&#xff0c;提升开发效率&#xff0c;帮您调试 Bug&#xff0c;节省…