笔记:定义一个函数,接收两个整数,分别代表年份和月份,返回这个月的最后一天是星期几,其中,0代表星期日。

本文主要是介绍笔记:定义一个函数,接收两个整数,分别代表年份和月份,返回这个月的最后一天是星期几,其中,0代表星期日。,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

  • 前言
  • 一、什么是定义一个函数,接收两个整数?
  • 二、编写代码
    • 1.代码
    • 2.优化代码
  • 总结


前言

题目:定义一个函数,接收两个整数,分别代表年份和月份,返回这个月的最后一天是星期几,其中,0代表星期日。

代码用于确定给定年份和月份的月末是星期几。
可以利用了蔡勒公式来计算日期对应的星期几,并考虑了闰年的情况。通过调用这个函数,你可以轻松地获取所需月份的最后一天是星期几,从而方便日历或时间表的处理。


一、什么是定义一个函数,接收两个整数?

示例:pandas 是基于NumPy 的一种工具,该工具是为了解决数据分析任务而创建的。
定义一个函数来接收两个整数,通常称为创建一个函数原型或声明一个函数。在大多数编程语言中,函数的定义包括函数名、参数列表以及函数体。例如,在Python中,定义一个函数来接收两个整数可以像这样:

def add(a, b):return a + b

在这个例子中,add 是函数的名称,它接收两个参数 ab,然后返回它们的和。

二、编写代码

1.代码

代码如下(示例):

# (4)定义一个函数,接收两个整数,分别代表年份和月份,返回这个月的最后一天是星期几,其中,0代表星期日。def day_of_week(year, month, day):# 如果月份为1月或2月,则将月份加上12,年份减去1if month < 3:month += 12year -= 1# 计算年份的后两位数k = year % 100# 计算年份的前两位数j = year // 100# 使用蔡勒公式计算星期几h = (day + (13 * (month + 1)) // 5 + k + k // 4 + j // 4 + 5 * j) % 7# 将结果转换为我们需要的格式,0代表星期日return (h + 5) % 7def last_day_of_month(year, month):# 如果是闰年且月份为2月,则返回闰年2月的最后一天是星期几if month == 2 and (year % 4 == 0 and year % 100 != 0 or year % 400 == 0):return day_of_week(year, month, 29)# 每个月的天数days_in_month = [0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31]# 返回这个月的最后一天是星期几return day_of_week(year, month, days_in_month[month])year = int(input("请输入年份:"))
month = int(input("请输入月份:"))
# 调用函数计算最后一天是星期几
weekday = last_day_of_month(year, month)
print("这个月的最后一天是星期", weekday)

代码定义了两个函数:

  1. day_of_week(year, month, day): 这个函数接收一个年份 year、一个月份 month 和一个日期 day,然后返回该日期对应的星期几,其中星期日用数字 0 表示。这个函数实现了蔡勒公式(Zeller’s Congruence),用于计算某一天是星期几的算法。

  2. last_day_of_month(year, month): 这个函数接收一个年份 year 和一个月份 month,然后返回该月份的最后一天是星期几。它首先检查是否是闰年且月份是 2 月,如果是,则调用 day_of_week 函数来计算闰年 2 月的最后一天是星期几;否则,根据每个月的天数表和 day_of_week 函数来计算一般情况下该月的最后一天是星期几。

代码的流程是比较清晰的,首先输入年份和月份,然后调用 last_day_of_month 函数计算该月最后一天是星期几,最后输出结果。

2.优化代码

代码如下(示例):

可以稍微提升一下可读性和效率。这里有一些优化建议:

  1. 使用枚举或字典代替列表:用枚举或字典定义每个月的天数,这样可以让代码更具可读性。
  2. 去掉函数调用中的不必要参数:因为 last_day_of_month 函数只需要年份和月份,所以不需要将天数传递给 day_of_week 函数。
  3. 去掉无用的变量:去掉 weekday 变量,直接在 print 语句中调用 last_day_of_month 函数。

下面是优化后的代码:

# 定义一个函数,用于计算给定日期是星期几,其中,0代表星期日。
def day_of_week(year, month, day):# 如果月份小于3(即1月或2月),将月份加上12,年份减去1if month < 3:month += 12year -= 1# 计算年份的后两位数k = year % 100# 计算年份的前两位数j = year // 100# 使用蔡勒公式计算星期几h = (day + (13 * (month + 1)) // 5 + k + k // 4 + j // 4 + 5 * j) % 7# 将结果转换为我们需要的格式,0代表星期日return (h + 5) % 7# 定义一个函数,用于确定给定年份和月份的最后一天是星期几
def last_day_of_month(year, month):# 定义每个月的天数days_in_month = {1: 31, 2: 28, 3: 31, 4: 30, 5: 31, 6: 30,7: 31, 8: 31, 9: 30, 10: 31, 11: 30, 12: 31}# 检查是否为闰年且是否为2月,如果是,则返回闰年2月的最后一天是星期几if month == 2 and (year % 4 == 0 and year % 100 != 0 or year % 400 == 0):return day_of_week(year, month, 29)# 返回给定月份的最后一天是星期几return day_of_week(year, month, days_in_month[month])# 获取用户输入的年份和月份
year = int(input("请输入年份:"))
month = int(input("请输入月份:"))# 调用函数并打印结果
print("这个月的最后一天是星期", last_day_of_month(year, month))

这段代码实现了两个函数:

  1. day_of_week(year, month, day): 这个函数根据给定的年份、月份和日期,计算出这一天是星期几,其中星期日用数字 0 表示。

  2. last_day_of_month(year, month): 这个函数根据给定的年份和月份,确定该月的最后一天是星期几。它首先确定该月的天数,然后根据是否是闰年以及是否是2月来决定最后一天是星期几。

代码的逻辑是:

  • 首先定义了两个函数,分别用于计算星期几和确定月份的最后一天是星期几。
  • last_day_of_month 函数中,通过判断是否是闰年和月份的天数,调用 day_of_week 函数来计算最后一天是星期几。
  • 最后,获取用户输入的年份和月份,调用函数并打印结果。

整体来说,这段代码通过蔡勒公式来计算星期几,结合月份的天数来确定月份的最后一天是星期几。


总结

在本文中,我们探讨了如何定义一个函数,接收两个整数,并编写了用于确定给定年份和月份的月末是星期几的代码。我们首先介绍了函数的定义和代码编写的基本概念,然后展示了使用蔡勒公式来计算日期对应的星期几的算法。

接着,我们编写了两个函数:

  1. day_of_week(year, month, day): 这个函数用于计算给定日期是星期几,其中星期日用数字 0 表示。我们使用了蔡勒公式来实现这个功能。

  2. last_day_of_month(year, month): 这个函数用于确定给定年份和月份的最后一天是星期几。我们根据每个月的天数和是否是闰年来确定最后一天是星期几,然后调用 day_of_week 函数来计算。

在编写代码的过程中,我们还进行了优化,提高了代码的可读性和效率。我们使用了枚举或字典来代替列表,去掉了不必要的函数调用参数,并简化了代码结构。

通过本文的学习,可以了解如何定义函数,接收两个整数,并编写用于处理日期和星期几的代码。这些知识和技能可以在日常编程和实际应用中发挥重要作用,帮助解决各种与日期相关的问题。

这篇关于笔记:定义一个函数,接收两个整数,分别代表年份和月份,返回这个月的最后一天是星期几,其中,0代表星期日。的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


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

相关文章

postgresql使用UUID函数的方法

《postgresql使用UUID函数的方法》本文给大家介绍postgresql使用UUID函数的方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录PostgreSQL有两种生成uuid的方法。可以先通过sql查看是否已安装扩展函数,和可以安装的扩展函数

MySQL字符串常用函数详解

《MySQL字符串常用函数详解》本文给大家介绍MySQL字符串常用函数,本文结合实例代码给大家介绍的非常详细,对大家学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql字符串常用函数一、获取二、大小写转换三、拼接四、截取五、比较、反转、替换六、去空白、填充MySQL字符串常用函数一、

C++中assign函数的使用

《C++中assign函数的使用》在C++标准模板库中,std::list等容器都提供了assign成员函数,它比操作符更灵活,支持多种初始化方式,下面就来介绍一下assign的用法,具有一定的参考价... 目录​1.assign的基本功能​​语法​2. 具体用法示例​​​(1) 填充n个相同值​​(2)

MySql基本查询之表的增删查改+聚合函数案例详解

《MySql基本查询之表的增删查改+聚合函数案例详解》本文详解SQL的CURD操作INSERT用于数据插入(单行/多行及冲突处理),SELECT实现数据检索(列选择、条件过滤、排序分页),UPDATE... 目录一、Create1.1 单行数据 + 全列插入1.2 多行数据 + 指定列插入1.3 插入否则更

PostgreSQL中rank()窗口函数实用指南与示例

《PostgreSQL中rank()窗口函数实用指南与示例》在数据分析和数据库管理中,经常需要对数据进行排名操作,PostgreSQL提供了强大的窗口函数rank(),可以方便地对结果集中的行进行排名... 目录一、rank()函数简介二、基础示例:部门内员工薪资排名示例数据排名查询三、高级应用示例1. 每

全面掌握 SQL 中的 DATEDIFF函数及用法最佳实践

《全面掌握SQL中的DATEDIFF函数及用法最佳实践》本文解析DATEDIFF在不同数据库中的差异,强调其边界计算原理,探讨应用场景及陷阱,推荐根据需求选择TIMESTAMPDIFF或inte... 目录1. 核心概念:DATEDIFF 究竟在计算什么?2. 主流数据库中的 DATEDIFF 实现2.1

MySQL中的LENGTH()函数用法详解与实例分析

《MySQL中的LENGTH()函数用法详解与实例分析》MySQLLENGTH()函数用于计算字符串的字节长度,区别于CHAR_LENGTH()的字符长度,适用于多字节字符集(如UTF-8)的数据验证... 目录1. LENGTH()函数的基本语法2. LENGTH()函数的返回值2.1 示例1:计算字符串

mybatis执行insert返回id实现详解

《mybatis执行insert返回id实现详解》MyBatis插入操作默认返回受影响行数,需通过useGeneratedKeys+keyProperty或selectKey获取主键ID,确保主键为自... 目录 两种方式获取自增 ID:1. ​​useGeneratedKeys+keyProperty(推

MySQL 中的 CAST 函数详解及常见用法

《MySQL中的CAST函数详解及常见用法》CAST函数是MySQL中用于数据类型转换的重要函数,它允许你将一个值从一种数据类型转换为另一种数据类型,本文给大家介绍MySQL中的CAST... 目录mysql 中的 CAST 函数详解一、基本语法二、支持的数据类型三、常见用法示例1. 字符串转数字2. 数字

Python内置函数之classmethod函数使用详解

《Python内置函数之classmethod函数使用详解》:本文主要介绍Python内置函数之classmethod函数使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 类方法定义与基本语法2. 类方法 vs 实例方法 vs 静态方法3. 核心特性与用法(1编程客