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

相关文章

hdu1171(母函数或多重背包)

题意:把物品分成两份,使得价值最接近 可以用背包,或者是母函数来解,母函数(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v)(1 + x^v+x^2v+.....+x^num*v) 其中指数为价值,每一项的数目为(该物品数+1)个 代码如下: #include<iostream>#include<algorithm>

PTA求一批整数中出现最多的个位数字

作者 徐镜春 单位 浙江大学 给定一批整数,分析每个整数的每一位数字,求出现次数最多的个位数字。例如给定3个整数1234、2345、3456,其中出现最多次数的数字是3和4,均出现了3次。 输入格式: 输入在第1行中给出正整数N(≤1000),在第二行中给出N个不超过整型范围的非负整数,数字间以空格分隔。 输出格式: 在一行中按格式“M: n1 n2 ...”输出,其中M是最大次数,n

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

系统架构师考试学习笔记第三篇——架构设计高级知识(20)通信系统架构设计理论与实践

本章知识考点:         第20课时主要学习通信系统架构设计的理论和工作中的实践。根据新版考试大纲,本课时知识点会涉及案例分析题(25分),而在历年考试中,案例题对该部分内容的考查并不多,虽在综合知识选择题目中经常考查,但分值也不高。本课时内容侧重于对知识点的记忆和理解,按照以往的出题规律,通信系统架构设计基础知识点多来源于教材内的基础网络设备、网络架构和教材外最新时事热点技术。本课时知识

整数Hash散列总结

方法:    step1  :线性探测  step2 散列   当 h(k)位置已经存储有元素的时候,依次探查(h(k)+i) mod S, i=1,2,3…,直到找到空的存储单元为止。其中,S为 数组长度。 HDU 1496   a*x1^2+b*x2^2+c*x3^2+d*x4^2=0 。 x在 [-100,100] 解的个数  const int MaxN = 3000

C++操作符重载实例(独立函数)

C++操作符重载实例,我们把坐标值CVector的加法进行重载,计算c3=c1+c2时,也就是计算x3=x1+x2,y3=y1+y2,今天我们以独立函数的方式重载操作符+(加号),以下是C++代码: c1802.cpp源代码: D:\YcjWork\CppTour>vim c1802.cpp #include <iostream>using namespace std;/*** 以独立函数

论文阅读笔记: Segment Anything

文章目录 Segment Anything摘要引言任务模型数据引擎数据集负责任的人工智能 Segment Anything Model图像编码器提示编码器mask解码器解决歧义损失和训练 Segment Anything 论文地址: https://arxiv.org/abs/2304.02643 代码地址:https://github.com/facebookresear

Spring 源码解读:自定义实现Bean定义的注册与解析

引言 在Spring框架中,Bean的注册与解析是整个依赖注入流程的核心步骤。通过Bean定义,Spring容器知道如何创建、配置和管理每个Bean实例。本篇文章将通过实现一个简化版的Bean定义注册与解析机制,帮助你理解Spring框架背后的设计逻辑。我们还将对比Spring中的BeanDefinition和BeanDefinitionRegistry,以全面掌握Bean注册和解析的核心原理。

两个月冲刺软考——访问位与修改位的题型(淘汰哪一页);内聚的类型;关于码制的知识点;地址映射的相关内容

1.访问位与修改位的题型(淘汰哪一页) 访问位:为1时表示在内存期间被访问过,为0时表示未被访问;修改位:为1时表示该页面自从被装入内存后被修改过,为0时表示未修改过。 置换页面时,最先置换访问位和修改位为00的,其次是01(没被访问但被修改过)的,之后是10(被访问了但没被修改过),最后是11。 2.内聚的类型 功能内聚:完成一个单一功能,各个部分协同工作,缺一不可。 顺序内聚:

函数式编程思想

我们经常会用到各种各样的编程思想,例如面向过程、面向对象。不过笔者在该博客简单介绍一下函数式编程思想. 如果对函数式编程思想进行概括,就是f(x) = na(x) , y=uf(x)…至于其他的编程思想,可能是y=a(x)+b(x)+c(x)…,也有可能是y=f(x)=f(x)/a + f(x)/b+f(x)/c… 面向过程的指令式编程 面向过程,简单理解就是y=a(x)+b(x)+c(x)