蓝桥杯-日期问题

本文介绍了一个日期解析问题,探讨如何将格式不一的历史文献日期转换为标准格式,并确保正确性和唯一性。文章提供了完整的Java代码实现,包括闰年判断、日期有效性验证及排序输出。
import java.util.Arrays;
import java.util.Scanner;

/**
问题描述
  小明正在整理一批历史文献。这些历史文献中出现了很多日期。小明知道这些日期都在1960年1月1日至2059年12月31日。
        令小明头疼的是,这些日期采用的格式非常不统一,有采用年/月/日的,有采用月/日/年的,还有采用日/月/年的。
        更加麻烦的是,年份也都省略了前两位,使得文献上的一个日期,存在很多可能的日期与其对应。
  比如02/03/04,可能是2002年03月04日、2004年02月03日或2004年03月02日。
  给出一个文献上的日期,你能帮助小明判断有哪些可能的日期对其对应吗?
输入格式
  一个日期,格式是"AA/BB/CC"。 (0 <= A, B, C <= 9)
输出格式
  输出若干个不相同的日期,每个日期一行,格式是"yyyy-MM-dd"。多个日期按从早到晚排列。
样例输入
02/03/04
样例输出
2002-03-04
2004-02-03
2004-03-02
数据规模和约定
  峰值内存消耗(含虚拟机) < 256M
  CPU消耗 < 1000ms
 * @author Vivinia
 *
 */
public class RiQi {

	public static void main(String[] args) {
		Scanner input=new Scanner(System.in);
		String str=input.nextLine();
		input.close();
		String[] s=str.split("/");
		int[][] tarr=new int[3][3];
		for(int i=0;i<3;i++)              //将三种可能存成数组,第一种直接输入,后边两种根据第一种改变顺序存入
			tarr[0][i]=Integer.parseInt(s[i]);
		
		tarr[1][0]=tarr[0][2];
		tarr[1][1]=tarr[0][0];
		tarr[1][2]=tarr[0][1];
		
		tarr[2][0]=tarr[0][2];
		tarr[2][1]=tarr[0][1];
		tarr[2][2]=tarr[0][0];
		for(int i=0;i<2;i++){     //从小到大排序
			int temp;
			if(tarr[i][0]>tarr[i+1][0]||(tarr[i][0]==tarr[i+1][0]&&tarr[i][1]>tarr[i+1][1])||(tarr[i][0]==tarr[i+1][0]&&tarr[i][1]==tarr[i+1][1]&&tarr[i][2]>tarr[i+1][2])){   //年份从小到大排序
				temp=tarr[i][0];
				tarr[i][0]=tarr[i+1][0];
				tarr[i+1][0]=temp;
				temp=tarr[i][1];
				tarr[i][1]=tarr[i+1][1];
				tarr[i+1][1]=temp;
				temp=tarr[i][2];
				tarr[i][2]=tarr[i+1][2];
				tarr[i+1][2]=temp;
			}
		}
		for(int i=0;i<3;i++){
			if(tarr[i][1]==0||tarr[i][2]==0)     //去掉月份和日期为0的
				continue;
			if(i>0)         //去掉相同的时间
				if(tarr[i][0]==tarr[i-1][0]&&tarr[i][1]==tarr[i-1][1]&&tarr[i][2]==tarr[i-1][2])
					continue;
			String ss="";
			if(tarr[i][0]>=0&&tarr[i][0]<=99&&tarr[i][1]>=1&&tarr[i][1]<=12&&tarr[i][2]>=0&&tarr[i][2]<=31){
				String year="";
				if(tarr[i][0]<60) {    //20..年
					year+="20";
					if(tarr[i][0]<10)
						year+="0";
				}else
					year+="19";
				year+=tarr[i][0];
				if(tarr[i][1]==2&&tarr[i][2]==29){         //去掉不是闰年2月还有29号的
					if(!((Integer.parseInt(year)%4==0&&Integer.parseInt(year)%100!=0)||Integer.parseInt(year)%400==0))
						continue;
				}
				ss+=year+"-";
				if(tarr[i][1]<10)
					ss+="0";
				ss+=tarr[i][1]+"-";
				if(tarr[i][2]<10)
					ss+="0";
				ss+=tarr[i][2];
			}
			if(!ss.equals(""))       //当ss为空格时,不能输出
				System.out.println(ss);
		}
	}

}

我是渣渣,代码有点繁琐,大佬勿喷。

注意以下几个问题:

1.闰年的情况;

2.输出是否从小到大;

3.日期是否重复;

4.年月日中是否有数字小于10;

5.以及最后我找了很久都没有发现的问题,是当数组中某种情况不符合条件时,我是用break跳出循环,但是最后在输出时,还是输出了ss的空字符,所以在输出时要判断一下;

<think>好的,我现在需要帮助用户寻找蓝桥杯竞赛中与Python日期处理相关的题目及解答。首先,我要回忆一下用户提供的引用内容,看看是否有相关的信息。 用户提到了四个引用,其中引用[2]是关于“python核酸日期”的题目,引用[3]和引用[4]可能也包含日期处理的题目。根据引用[2],题目可能涉及到计算日期,比如给定一个日期,要求计算之后或之前的某一天。例如,核酸日期问题可能需要计算核酸的有效期,比如两天后的日期。 接下来,我需要确定用户的需求是具体的题目示例和解决方法。可能需要从提供的引用中提取相关题目的描述,并给出Python的解决代码。例如,引用[2]中的核酸日期问题,可能要求输入一个日期,输出n天后的日期,考虑闰年等情况。 然后,我需要考虑如何解析日期,Python中的datetime模块可以方便地处理日期加减,但蓝桥杯比赛中有时会限制使用某些库,可能需要手动实现日期计算。不过根据实际情况,datetime模块通常是允许的,所以使用它会更高效。 另外,引用[3]中的试题C是完全日期问题,可能需要判断一个日期是否是完全平方数或其他条件,这涉及到日期的各个部分(年、月、日)的组合处理。例如,将年月日数字连起来形成一个数,判断是否为完全平方数。 最后,整理这些信息,给出具体的题目例子和对应的解答代码,确保代码符合Python语法,并处理好边界情况,比如闰年2月的天数,月份和日期的进位等。同时,可能需要解释解题思路,帮助用户理解如何处理日期相关问题。</think>根据蓝桥杯竞赛中与日期处理相关的Python题目,以下是典型例题及解析: ### 示例1:核酸日期(STEMA选拔赛真题) **题目要求** 输入一个日期(格式:yyyy-mm-dd)和整数n,输出这个日期n天后的日期[^2]。 **解题思路** 1. 使用Python的`datetime`模块处理日期加减 2. 注意跨月、跨年时的自动进位 3. 需处理输入输出格式匹配 **参考代码** ```python from datetime import datetime, timedelta date_str, n = input().split() n = int(n) date = datetime.strptime(date_str, "%Y-%m-%d") result = date + timedelta(days=n) print(result.strftime("%Y-%m-%d")) ``` --- ### 示例2:完全日期(第十二届国赛真题) **题目要求** 若一个日期的年、月、日数值之和是完全平方数,则称为完全日期。 给定时间段(2001-01-01到2021-12-31),统计完全日期数量[^3]。 **关键步骤** 1. 遍历日期范围内的每一天 2. 计算年月日各位数之和 3. 判断是否为完全平方数 **核心代码片段** ```python import math from datetime import datetime, timedelta start = datetime(2001, 1, 1) end = datetime(2021, 12, 31) delta = end - start cnt = 0 for i in range(delta.days + 1): current = start + timedelta(days=i) total = current.year + current.month + current.day s = int(math.sqrt(total)) if s * s == total: cnt += 1 print(cnt) # 正确答案需要实际计算验证 ``` --- ### 示例3:星期计算(省赛模拟题) **题目要求** 已知2023年10月1日是星期日,输入一个2023年的日期,输出对应星期几。 **实现方法** 1. 计算两个日期的差值 2. 使用模7运算确定星期 **代码实现** ```python from datetime import datetime ref_date = datetime(2023, 10, 1) # 已知周日 input_date = datetime.strptime(input(), "%Y-%m-%d") delta = (input_date - ref_date).days weekday = (0 + delta) % 7 # 0代表周日 print(["日","一","二","三","四","五","六"][weekday]) ``` --- ### 日期处理通用技巧 1. **闰年判断**: ```python def is_leap(year): return year % 400 == 0 or (year % 4 == 0 and year % 100 != 0) ``` 2. **月份天数映射**: ```python month_days = [0,31,28,31,30,31,30,31,31,30,31,30,31] if is_leap(year): month_days[2] = 29 ``` 3. **禁止使用datetime时的解法**: 手动计算日期差值时,可采用: -日期转换为从基准年开始的总天数 - 处理闰年时每年天数不同的问题 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值