笔记:定义一个函数,接收两个整数,分别代表年份和月份,返回这个月的最后一天是星期几,其中,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

相关文章

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

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

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

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

C# 比较两个list 之间元素差异的常用方法

《C#比较两个list之间元素差异的常用方法》:本文主要介绍C#比较两个list之间元素差异,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. 使用Except方法2. 使用Except的逆操作3. 使用LINQ的Join,GroupJoin

Python函数作用域示例详解

《Python函数作用域示例详解》本文介绍了Python中的LEGB作用域规则,详细解析了变量查找的四个层级,通过具体代码示例,展示了各层级的变量访问规则和特性,对python函数作用域相关知识感兴趣... 目录一、LEGB 规则二、作用域实例2.1 局部作用域(Local)2.2 闭包作用域(Enclos

MySQL count()聚合函数详解

《MySQLcount()聚合函数详解》MySQL中的COUNT()函数,它是SQL中最常用的聚合函数之一,用于计算表中符合特定条件的行数,本文给大家介绍MySQLcount()聚合函数,感兴趣的朋... 目录核心功能语法形式重要特性与行为如何选择使用哪种形式?总结深入剖析一下 mysql 中的 COUNT

MySQL 中 ROW_NUMBER() 函数最佳实践

《MySQL中ROW_NUMBER()函数最佳实践》MySQL中ROW_NUMBER()函数,作为窗口函数为每行分配唯一连续序号,区别于RANK()和DENSE_RANK(),特别适合分页、去重... 目录mysql 中 ROW_NUMBER() 函数详解一、基础语法二、核心特点三、典型应用场景1. 数据分

MySQL数据库的内嵌函数和联合查询实例代码

《MySQL数据库的内嵌函数和联合查询实例代码》联合查询是一种将多个查询结果组合在一起的方法,通常使用UNION、UNIONALL、INTERSECT和EXCEPT关键字,下面:本文主要介绍MyS... 目录一.数据库的内嵌函数1.1聚合函数COUNT([DISTINCT] expr)SUM([DISTIN

Python get()函数用法案例详解

《Pythonget()函数用法案例详解》在Python中,get()是字典(dict)类型的内置方法,用于安全地获取字典中指定键对应的值,它的核心作用是避免因访问不存在的键而引发KeyError错... 目录简介基本语法一、用法二、案例:安全访问未知键三、案例:配置参数默认值简介python是一种高级编

python 常见数学公式函数使用详解(最新推荐)

《python常见数学公式函数使用详解(最新推荐)》文章介绍了Python的数学计算工具,涵盖内置函数、math/cmath标准库及numpy/scipy/sympy第三方库,支持从基础算术到复杂数... 目录python 数学公式与函数大全1. 基本数学运算1.1 算术运算1.2 分数与小数2. 数学函数

SpringBoot中使用Flux实现流式返回的方法小结

《SpringBoot中使用Flux实现流式返回的方法小结》文章介绍流式返回(StreamingResponse)在SpringBoot中通过Flux实现,优势包括提升用户体验、降低内存消耗、支持长连... 目录背景流式返回的核心概念与优势1. 提升用户体验2. 降低内存消耗3. 支持长连接与实时通信在Sp