IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 每日一题系列:美国节日 -> 正文阅读

[数据结构与算法]每日一题系列:美国节日

链接:https://www.nowcoder.com/questionTerminal/d95d98a2f96e49078cd7df84ba0c9d79
来源:牛客网

和中国的节日不同,美国的节假日通常是选择某个月的第几个星期几这种形式,因此每一年的放假日期都不相同。具体规则如下:

  • 1月1日:元旦
  • 1月的第三个星期一:马丁·路德·金纪念日
  • 2月的第三个星期一:总统节
  • 5月的最后一个星期一:阵亡将士纪念日
  • 7月4日:美国国庆
  • 9月的第一个星期一:劳动节
  • 11月的第四个星期四:感恩节
  • 12月25日:圣诞节
    现在给出一个年份,请你帮忙生成当年节日的日期

在这里插入图片描述
示例:
在这里插入图片描述
案列已全部通过
在这里插入图片描述

import java.util.*;
public class Main{
           public static boolean isRn(int year) {//判断是不是闰年
        if(((year%4==0)&&year%100!=0)||(year%400==0)){
            return true;
        }
           return false;

    }
    public static   int day_of_week(int year, int month, int day)//蔡勒公式,给年月日计算出这天是星期几
    {
        if (month == 1 || month == 2)
        {
            month += 12;
            year -= 1;
        }

        int century = year / 100;
        year %= 100;
        int week = year + (year / 4) + (century / 4) - 2 * century + 26 * (month + 1) / 10 + day -
                1;
        week = (week % 7 + 7) % 7;

        if (week == 0)
        {
            week = 7;
        }

        return week;
    }

    public static void printFunc(int y,int m,int d) {
        String str1="-";
        String str2="-";
        boolean f1=false;
        boolean f2=false;
        if(m/10==0){
            f1=true;
            str1+=0;
        }
        if(d/10==0){
            f2=true;
            str2+=0;
        }
        System.out.println(y + str1 + m + str2 + d);
    }
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        while (scanner.hasNext()) {
            int y = scanner.nextInt();
            boolean f=isRn(y);
            for (int m = 1; m <= 12; ) {
                    int x = 0;
                    if (m % 2 == 0) {//偶数月
                        if (m == 2) {
                            if (f) {
                                x = 29;
                            } else {
                                x = 28;
                            }
                        } else {
                            x = 30;
                        }
                    } else {
                        x = 31;
                    }
                    int tmp=day_of_week(y,m,1);//这年这月第一天是星期几
                    boolean flg=false;//后面用于标记劳动节的
                    for (int d = 1; d <= x; d++) {
                        int j=(d+tmp)/7+1;//第几个星期
                        // 注意,第几个星期!=第几个星期几
                        //比如你这个月是星期4是1号,那你第一个星期3,是第二个星期才出现的

                        int w = day_of_week(y,m,d);//这年这月这日是星期几
                        //蔡勒公式,给一个年月日计算是星期几

                        if ((m == 1 && d == 1) || (m == 7 && d == 4) || (m == 12 && d == 25)) {//指定节日
                            if(m<10){
                                System.out.println(y + "-0" + m + "-0" + d);
                            }else{
                                System.out.println(y + "-" + m + "-" + d);
                            }
                            continue;
                        } else if (m == 1  && w == 1) {//马丁路德金纪念日
                            if(1<tmp){
                                //比如你这个月是星期3是1号,那你第三个星期1,是第四个星期才出现的
                                if(4==j){
                                    printFunc(y,m,d);
                                }
                            }else{//这个月第一天就是星期1,那第三个星期1,就是第三个星期出现
                                if(3==j){
                                    printFunc(y,m,d);
                                }
                            }
                        } else if (m == 2  && w == 1) {//总统节
                            if(1<tmp){
                                if(4==j){
                                    printFunc(y,m,d);
                                }
                            }else{
                                if(3==j){
                                    printFunc(y,m,d);
                                }
                            }
                        } else if (m == 5  && w == 1) {//阵亡将士纪念日
                            //五月第一天是星期一,最后一个星期一是在 第5个星期
                            //五月第一天是星期日,最后一个星期一是在 第6个星期
                            int k=0;

                            for(int a=0;a<7;a++){
                                if (flg==true){
                                    break;
                                }
                                if(day_of_week(y,5,31-a)==1){
                                    printFunc(y,m,31-a);
                                    flg=true;
                                }
                            }
                        } else if (m == 9 && w == 1) {//劳动节
                            if(1<tmp){
                                if(2==j){
                                    printFunc(y,m,d);
                                }
                            }else{
                                if(1==j){
                                    printFunc(y,m,d);
                                }
                            }
                        } else if (m == 11 && w == 4) {//感恩节
                            if(4<tmp){
                                if(5==j){
                                    printFunc(y,m,d);
                                }
                            }else{
                                if(4==j){
                                    printFunc(y,m,d);
                                }
                            }
                        }
                    }
                    m++;
                }

            System.out.println();
        }
    }
}
  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-05-12 16:37:25  更:2022-05-12 16:37:51 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/26 3:44:17-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码