藍橋杯 算法提高 日期計算

  算法提高 日期計算  
時間限制:1.0s   內存限制:256.0MB問題描述已知2011年11月11日是星期五,問YYYY年MM月DD日是星期幾?注意考慮閏年的情況。尤其是逢百年不閏,逢400年閏的情況。
輸入格式輸入只有一行YYYY MM DD
輸出格式輸出只有一行W
數據規模和約定1599 <= YYYY <= 29991 <= MM <= 121 <= DD <= 31,且確保測試樣例中YYYY年MM月DD日是一個合理日期1 <= W <= 7,分別代表周一到周日
樣例輸入
2011 11 11
樣例輸出
5

c++:

 1 #include<iostream> 
 2 #include<cstring>
 3 #include<cstdio>
 4 using namespace std;
 5 
 6 int a[2][13]={{0, 31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31},{0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31}};
 7 
 8 bool isRun(int year){//判斷是否為閏年
 9     if(year % 4 == 0 && year % 100 != 0 || year % 400 == 0)
10         return true;
11     return false;
12 }
13 
14 int calDay(int year){
15     int index = 0;
16     if(!isRun(year)) index = 1;
17     int tot = 0;
18     for(int i=1; i<=12; ++i)
19         tot += a[index][i];
20     return tot;
21 }
22 
23 int Day(int y, int m, int d){//計算從0年0月0日到y年m月d日的時間天數 
24     int ans = 0;
25     for(int i=1; i<y; ++i)
26         ans+=calDay(i);
27     int index = 0;
28     if(!isRun(y)) index = 1;
29     for(int i=1; i<m; ++i)
30         ans += a[index][i];
31     ans += d;
32     return ans;
33 }
34 
35 int main(){
36     int y, m, d;
37     cin>>y>>m>>d;
38     int diff = Day(y, m, d) - Day(2011, 11, 11);//已知2011-11-11這一天是星期5 
39     if(diff > 0) cout<<(4+diff%7)%7+1<<endl;
40     else{
41         for(int i=1; i<=7; ++i)
42             if((i-1 + -diff%7)%7 + 1 == 5){
43                 cout<<i<<endl;
44                 break;
45             }
46     }
47     return 0;
48 }

?

轉載于:https://www.cnblogs.com/hujunzheng/p/4395845.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/531506.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/531506.shtml
英文地址,請注明出處:http://en.pswp.cn/news/531506.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

java JFileChooser選擇文件和保存文件

//文件過濾器import java.io.File;import javax.swing.filechooser.FileFilter;public class MyFilter extends FileFilter{private String[] filterString null;public MyFilter(String[] filStrings){this.filterString filStrings;}public boolean accept(File file){if(f…

指針詳解

c語言相比其他高級語言來說,更接近于對計算機硬件的操作,而指針的應用更是為我們對硬件的操作插上了翅膀,所以指針是嵌入式編程不可少的一部分,在一定意義上說,指針是c語言的精髓。 歡迎加入嵌入式學習群:559601187 一、 什么是指針 在計算機中,數據時存放在內存中的,…

反質數問題,求不大于n的最大反質數

反質數&#xff1a;設f(n)表示n個約數的個數&#xff0c;如果對于任意x有0<x<n, f(x) < f(n),那么n就是一個反質數我們都知道對于任意一個數n&#xff0c;都可以用質數乘積的形式表示出來&#xff1a;x p1^k1p2^k2...pn^kn一個數n如果可以表示成 n p1^k1 p2^k2, 那…

c語言之結構

今天來說一下C語言里的結構體(struct)、共用體(l聯合體)union、枚舉。 歡迎加入嵌入式學習群&#xff1a;559601187 &#xff08;一&#xff09;結構體&#xff1a;struct 1.1 概念 是一種自定義的數據類型結構體是構造類型的一種不同數據類型的集合地址空間連續&#xff0c;…

貓和老鼠 藍橋杯/手速/暴力練習賽(暴力搜索)

貓和老鼠 藍橋杯&#xff0f;手速&#xff0f;暴力練習賽 【題目描述】貓和老鼠在10*10 的方格中運動&#xff0c;例如&#xff1a;*...*...........*......*...*...............*.C....*.....*......*........M......*...*.*.....*.*......C貓&#xff08;CAT&#xff09;M老鼠…

STM32 4*4矩陣按鍵

本文章講述了如何用STM32編寫4*4矩陣按鍵程序&#xff0c;先簡單介紹一下掃描的基本方法&#xff1a;1.反轉法 2.行列掃描。本文主要介紹行列掃描 歡迎加入嵌入式學習群&#xff1a;559601187 &#xff08;一&#xff09;代碼如下 /*****************************************…

編譯原理:正規式轉變成DFA算法

//將正規式轉變成NFApackage hjzgg.formal_ceremony_to_dfa;import java.util.ArrayList;class Edge{public int u, v;public char key;public Edge(int u, int v, char key) {super();this.u u;this.v v;this.key key;}Overridepublic String toString() {return u "…

C語言實現音樂播放器(Linux madplay)

&#xff08;一&#xff09;需求分析 1.掃描指定路徑下的音樂&#xff0c;并顯示出來 2.實現音樂的播放、暫停、上一首和下一首的功能 3.程序退出釋放內存資源 &#xff08;二&#xff09;思路 1.掃描出指定路徑下的音樂文件(便利指定文件夾&#xff0c;找出音頻文件放在數組…

編譯原理(簡單自動詞法分析器LEX)

編譯原理&#xff08;簡單自動詞法分析器LEX&#xff09;源程序下載地址&#xff1a; http://files.cnblogs.com/files/hujunzheng/%E6%B1%87%E7%BC%96%E5%8E%9F%E7%90%86%E7%AE%80%E5%8D%95LEX%EF%BC%88%E8%AF%8D%E6%B3%95%E8%87%AA%E5%8A%A8%E5%88%86%E6%9E%90%E5%99%A8%EF%…

虛擬機中安裝linux

&#xff08;一&#xff09;前言 就在昨天電腦的固態突然崩掉&#xff0c;無奈重新把系統裝在的以前的硬盤上&#xff0c;為了能夠繼續工作重新配置嵌入式linux系統開發環境&#xff0c;本教程主要記錄在虛擬機中安裝linux。 &#xff08;二&#xff09;環境準備 虛擬機&…

編譯原理簡單語法分析器(first,follow,分析表)源碼下載

編譯原理&#xff08;簡單語法分析器下載&#xff09; http://files.cnblogs.com/files/hujunzheng/%E5%8A%A0%E5%85%A5%E5%90%8C%E6%AD%A5%E7%AC%A6%E5%8F%B7%E5%90%8E%E7%9A%84%E8%AF%AD%E6%B3%95%E5%88%86%E6%9E%90%E5%99%A8.zip 轉載于:https://www.cnblogs.com/hujunzheng…

Ubuntu設置root登錄

1.、Ubuntu 管理員用戶 root 默認沒有密碼&#xff0c;在使用前最好添加密碼&#xff0c;使用指令&#xff1a; sudo passwd root 注意&#xff1a;命令行輸入密碼時不顯示&#xff0c;輸入時需注意密碼的準確性&#xff1b; 2、Ubuntu 想要用 root 帳戶登錄&#xff0c;可在普…

vim配置之spacevim

為了更好的利用vim&#xff0c;我們一般需要自己配置&#xff0c;今天介紹了一下經常用的spacevim &#xff08;一&#xff09;配置環境 Ubuntu16.04vim 7.4版本以上(必須&#xff01;&#xff01;) &#xff08;二&#xff09;安裝spacevim 1.檢查vim的版本&#xff1a; v…

Ubuntu更換gnome桌面環境后不能root登錄

安裝完Ubuntu后感覺界面有點丑陋&#xff0c;安裝了gnome桌面環境試一下 sudo apt-get install gnome-shell sudo apt-get install ubuntu-gnome-desktop如果選擇了lightdm后可以使用sudo dpkg-reconfigure gdm3 重新改回gdm3 sudo apt-get install unity-tweak-tool sudo ap…

Ubuntu下安裝tilix終端仿真器

安裝環境 Ubuntu 16.04 操作步驟 首先添加這個終端模擬器倉庫的公鑰。這里我都是以root超級用戶權限操作的&#xff0c;如果沒有的話&#xff0c;請在命令前面加sudo。 add-apt-repository ppa:webupd8team/terminixapt update安裝Tilix。 apt install tilix安裝完成測試結…

(擴展歐幾里德算法)zzuoj 10402: C.機器人

10402: C.機器人 Description Dr. Kong 設計的機器人卡爾非常活潑&#xff0c;既能原地蹦&#xff0c;又能跳遠。由于受軟硬件設計所限&#xff0c;機器人卡爾只能定點跳遠。若機器人站在&#xff08;X&#xff0c;Y&#xff09;位置&#xff0c;它可以原地蹦&#xff0c;但只可…

vim配置之snippets代碼塊

&#xff08;一&#xff09;目的 我們在編寫程序的過程中&#xff0c;經常會敲一些重復的代碼&#xff0c;我們可以利用snippets來達到輸入簡寫來敲出完整的代碼 &#xff08;二&#xff09;安裝步驟 安裝使用Vundle,沒有vbundle的先執行下面的命令 git clone https://gith…

Ubuntu 16.04 安裝CodeBlocks

博主作為嵌入式開發者&#xff0c;經常使用c/c開發&#xff0c;所以今天來裝一下經常使用的codeblocks&#xff0c;linux下代碼編輯器有好多&#xff0c;可以上網搜一下linux下常用的代碼編輯器就會出來好多&#xff0c;codeblocks作為c/c編輯器很方便&#xff0c;無論是安裝還…

svn的安裝與使用

Eclipse安裝SVN插件 1、下載最新的Eclipse&#xff0c;我的版本是3.7.2 indigo(Eclipse IDE for Java EE Developers)版 如果沒有安裝的請到這里下載安裝&#xff1a;http://eclipse.org/downloads/ 2、下載SVN插件subclipse&#xff0c;安裝方法有兩種.那種綠色的以link方式安…

c語言實現跳動的心

本文章分為兩部分&#xff1a;第一部分為實現多彩的心&#xff0c;第二部分是實現心得跳動&#xff0c;兩個代碼均獨立運行 本篇文章轉載自公眾號&#xff1a; C語言程序設計基礎知識 &#xff08;一&#xff09;C語言實現多彩的心 實現過程其實很簡單 首先使用for循環繪制心…