算法09 日期相關模擬算法【C++實現】

這是《C++算法寶典》算法篇的第09節文章啦~

如果你之前沒有太多C++基礎,請點擊👉專欄:C++語法入門,如果你C++語法基礎已經爐火純青,則可以進階算法👉專欄:算法知識和數據結構👉專欄:數據結構啦

目錄

?前言

📕得到某年某月的天數

🧠普通閏年

🧠世紀閏年

📕得到某年某月的天數

📕判斷日期的合法性

📕訓練:第n天的日期

🧠第n天的日期參考代碼

📕訓練:日期距離

🧠日期距離參考代碼


前言

無論是中小學編程競賽還是大學生編程競賽,日期模擬都是經常會出現的題目。

日期模擬經常會出現以下題型:

  • 得到某年某月的天數
  • 判斷給定日期的合法性
  • 給定年份,求這一年第n天的日期
  • 給定年月日,求經過n天后的日期
  • 查找兩個日期之間有多少個回文日期... ...

得到某年某月的天數

得到某年某月的天數問題經常會作為其他問題的模板來使用。

首先我們需要存儲一年中所有月份相對應的天數

int day[] = {0,31,28,31,30,31,30,31,31,30,31,30,31}

其中day[1]表示一月份最多31天,2月份先賦值為28天,具體天數還需要檢測年份是否是閏年,如果是閏年還需要+1天

閏年分為兩種:

普通閏年

年份是4的倍數,但不是100的倍數,例如2004、2020年等

世紀閏年

是400的倍數,例如1900不是世紀閏年,2000是世紀閏年,即:

if(year % 4 == 0 && year % 100 != 0 || year % 400 == 0)是閏年;else不是;

得到某年某月的天數

當月份不是2月時,就返回指定當前月份初始天數

當月份是2月時,判斷年份是否是閏年,當年份為閏年成立時,leap值為1,不成立時值為0,初始天數加上leap的值即為2月份天數

int days[] = {0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};// 得到某年某月的天數int check(int y, int m){if(m != 2) return days[m];else{//特判 2 月int leap = (y % 4 == 0 && y % 100 != 0 || y % 400 == 0);return days[m] + leap;}}

判斷日期的合法性

一般這樣的題型會先給你一個格式,看是否符合這個格式,比如要滿足20230701這樣的格式才是合法的。

首先你需要分離出年份,再分離出月份,最后分離出日。

再分別判斷年月日是否符合題意

if(m<1||m>12) 則月份不符合if(d<1||d>(指定月份的總天數)) 則日不符合

注:年份一般不需要檢查,但也要視題意而定

訓練:第n天的日期

給定一個年份y和一個整數d,問這一年的第d天是幾月幾日?注意閏年的2月有29天。滿足下面條件之一的是閏年:

1、年份是4的整數倍,而且不是100的整數倍;

2、年份是400的整數倍。

【輸入描述】輸入的第一行包含一個整數y,表示年份,年份在1900到2015之間(包含1900和2015)。

輸入的第二行包含一個整數d,d在1至365之間。

【輸出描述】輸出兩行,每行一個整數,分別表示答案的月份和日期。

【樣例輸入1】

2015

80

【樣例輸出】

3

21

第n天的日期參考代碼

#include <iostream>
using namespace std;
int day[13]={0,31,0,31,30,31,30,31,31,30,31,30,31};
bool check(int n) ?//判斷閏年
{if(n%400==0||(n%4==0&&n%100!=0)) return true;return false;
}
int main()
{int m,n;cin>>m>>n;if(check(m)) ?day[2]=29;else ?day[2]=28;for(int j=1;j<=12;j++){n-=day[j];if(n<0){cout<<j<<endl<<day[j]+n;break;}if(n==0){cout<<j<<endl<<day[j];break;}}return 0;
}

訓練:日期距離

?輸入一個的日期,輸出它和2014年5月17日相差有多少天?注意閏年的2月有29天。滿足下面條件之一的是閏年:

1、年份是4的整數倍,而且不是100的整數倍;

2、年份是400的整數倍。

【輸入描述】輸入的第一行包含一個整數y,表示年份,年份在1到2014之間(包含1和2014)。

輸入的第二行包含一個整數m,表示月份,m在1至12之間。

輸入的第三行包含一個正整數d,表示日期,d在1至31之間。

【輸出描述】輸出兩個日期之間相差的天數。

【輸入樣例】

1988

7

3

【輸出樣例】

9449

日期距離參考代碼

#include <iostream>
using namespace std;
int day[13]={0,31,0,31,30,31,30,31,31,30,31,30,31};
bool check(int k) ?//判斷閏年
{if(k%400==0||(k%4==0&&k%100!=0))return true;return false;
}
int sum;//計算總天數
int main()
{int m,n,d;cin>>m>>n>>d;if(check(m)) ?day[2]=29;else ?day[2]=28;for(int i=m+1;i<2014;i++) ?//計算完整的年份天數{if(check(i)) ?sum+=366;else sum+=365;}if(m==2014){for(int i=n+1;i<5;i++) //計算完整的月份的天數sum+=day[i];if(n==5) sum+=17-d;else sum+=day[n]-d+17;}else{sum+=137; //2014.1.1~2014.5.17總天數for(int i=n+1;i<=12;i++) ??//算上完整月份天數sum+=day[i];sum+=day[n]-d; ??}cout<<sum<<endl;return 0;
}

從入門到算法,再到數據結構,查看全部文章請點擊此處?????icon-default.png?t=N7T8http://www.bigbigli.com/

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

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

相關文章

計算斜率,判斷斜率

#include <stdio.h> #include <stdlib.h> #include <math.h> #include <stdbool.h>// 定義常量 #define LOW_COOK_WINDOW_SIZE 20 // 滑動窗口大小&#xff0c;10個樣本點&#xff08;10秒&#xff09; #define LOW_COOK_SLOPE…

Java代碼生成器(開源版本)

一、在線地址 Java在線代碼生成器&#xff1a;在線訪問 二、頁面截圖 三、核心功能 支持Mybatis、MybatisPlus、Jpa代碼生成使用 antlr4 解析SQL語句&#xff0c;保證了SQL解析的成功率支持自定義包名、作者名信息支持自定義方法名、接口地址支持自定義選擇是否生成某個方法…

16-Python Pandas聚合函數

Python Pandas聚合函數 窗口函數可以與聚合函數一起使用&#xff0c;聚合函數指的是對一組數據求總和、最大值、最小值以及平均值的操作。 應用聚合函數 首先讓我們創建一個 DataFrame 對象&#xff0c;然后對聚合函數進行應用。 import pandas as pd import numpy as np d…

SQL中的子查詢和CTE(with ....as..)

第一次看到with as 這種類似于python中讀文件的寫法還是挺疑惑的&#xff0c;其實它是CTE&#xff0c;功能和子查詢很類似但又有不同點&#xff0c;在實際應用場景中具有著獨特作用。 子查詢 子查詢是在主查詢中的嵌套查詢&#xff0c;可以出現在SELECT、FROM、WHERE等子句中…

ai除安卓手機版APP軟件一鍵操作自動渲染去擦消稀缺資源下載

安卓手機版&#xff1a;點擊下載 蘋果手機版&#xff1a;點擊下載 電腦版&#xff08;支持Mac和Windows&#xff09;&#xff1a;點擊下載 一款全新的AI除安卓手機版APP&#xff0c;一鍵操作&#xff0c;輕松實現自動渲染和去擦消效果&#xff0c;稀缺資源下載 1、一鍵操作&…

數學建模(1):期末大亂燉

1 概述&#xff01;&#xff01; 1.1 原型和模型 原型&#xff1a;客觀存在的研究對象稱為原型&#xff0c;也稱為“系統”、“過程”。 機械系統、電力系統、化學反應過程、生產銷售過程等都是原型&#xff1b; 研究原型的結構和原理&#xff0c; 從而進行優化、預測、評價…

Perl編程藝術:深入探索Tie機制的魔力

&#x1f31f; Perl編程藝術&#xff1a;深入探索Tie機制的魔力 在Perl的世界里&#xff0c;tie功能是一種極其強大的特性&#xff0c;它允許程序員將變量綁定到一個對象上&#xff0c;從而改變這個變量的默認行為。這種機制為變量提供了一種代理訪問方式&#xff0c;使得變量…

Jedis、Lettuce、RedisTemplate連接中間件

jedis就像jdbc一樣&#xff0c;用于兩個端直接的連接。 1.創建Spring項目 這里不過多贅述... 2.導入連接工具jedis 在pom文件中導入jedis的依賴。 <dependency><groupId>redis.clients</groupId><artifactId>jedis</artifactId><version&…

結合數據索引結構看SQL的真實執行過程

引言 關于數據庫設計與優化的前幾篇文章中&#xff0c;我們提到了數據庫設計優化應該遵守的指導原則、數據庫底層的索引組織結構、數據庫的核心功能組件以及SQL的解析、編譯等。這些其實都是在為SQL的優化、執行的理解打基礎。 今天這篇文章&#xff0c;我們以MySQL中InnoDB存…

vim卡死

有些時候使用vim的時候莫名其妙的會卡死&#xff0c;導致輸入不了內容。查了一下資料發現&#xff0c;其實并不是vim卡死&#xff0c;而是在使用vim的工程中帶入了許多Windows上的使用習慣&#xff0c;比如“Ctrl-s”保存等&#xff0c;這可能會與Linux平臺的有些快捷鍵沖突。c…

Oracle PL / SQL 表 table

關系數據庫允許您在數據庫管理系統&#xff08;DBMS&#xff09;中存儲多個表。 您可以使用計算機上的查詢語言來操作表中的數據。 當前的查詢語言是結構化查詢語言&#xff08;SQL&#xff09;。 SQL是一組無關的命令&#xff0c;用于操作關系數據庫管理系統&#xff08;RD…

CleanMyMacX2024免費且強大的mac電腦系統優化工具

如果你的Mac電腦出現了存儲空間不足、運行緩慢、電池電量消耗過快等問題&#xff0c;那么CleanMyMacX這款軟件或許能為你提供解決方案。作為一款強大的系統優化工具&#xff0c;它能夠幫助用戶清理垃圾文件、優化內存和電池使用&#xff0c;從而提升Mac的性能表現&#xff0c;讓…

后端之路第三站(Mybatis)——XML文件操作sql

一、XML映射文件是啥 前面我們學過了在Mapper接口用注解的方式來操作sql語句 那么XML映射文件就另一種操作sql語句的方法 為什么還要有這么個玩意&#xff1f; 我簡單說就是&#xff1a;如果有的sql特別復雜的話&#xff0c;比如需要【動態sql】的話&#xff0c;就得用到XM…

【Android面試八股文】Fragment的add和replace的區別,分別對Fragment的生命周期有什么影響?

文章目錄 一、Fragment的add和replace的區別 ,分別對Fragment的生命周期有什么影響?1.1 `add` 方法1.2 `replace` 方法1.3 應用場景1.4 Fragment事務操作提交流程1.5 replace操作的本質是不是就是remove操作和add操作的組合?1.6 示例代碼:將一個已經存在的 `FragmentA` 替換…

電腦開機之后,鍵盤鼠標需要重新插拔才能正常使用?

前言 小白平時修電腦修得多&#xff0c;總是會遇到各種各樣的奇葩問題。這不&#xff0c;又有一位小伙伴來咨詢&#xff1a;電腦開機之后&#xff0c;鍵盤鼠標都不能用&#xff0c;需要重新插拔一下才能正常使用。 嘖嘖嘖&#xff0c;真的是很奇怪的問題&#xff0c;基本上沒見…

分頁緩存與下拉刷新的整合原理 - DoraPageDatabaseCacheRepository

何為分頁緩存&#xff1f; 顧名思義&#xff0c;分頁緩存就是邊分頁邊緩存&#xff0c;分頁通常使用下拉刷新控件實現&#xff0c;而緩存通常說的是指磁盤緩存&#xff0c;即保存到數據庫中&#xff0c;數據庫本身也是一個索引文件。 為什么緩存還要分頁&#xff1f; 在很大…

SSH 無密登錄配置流程

一、免密登錄原理 非對稱加密&#xff1a; 由于對稱加密的存在弊端&#xff0c;就產生了非對稱加密&#xff0c;非對稱加密中有兩個密鑰&#xff1a;公鑰和私鑰。公鑰由私鑰產生&#xff0c;但卻無法推算出私鑰&#xff1b;公鑰加密后的密文&#xff0c;只能通過對應的私鑰來解…

光速入門 Tailwind CSS

文章目錄 入門安裝IDE 設置使用預編譯器生產環境優化 基礎概念分層指令tailwindlayerapplyconfig 函數theme()screen() 基礎案例怎么設置屬性任意值&#xff1f;hover 父元素時&#xff0c;怎么選中子元素添加樣式&#xff1f;添加 animation 動畫 配置主題 Tailwind CSS 中文網…

.so: file not recognized: file format not recognized

項目場景&#xff1a; 自Linux 4.8起&#xff0c;傳統的GPIO sysfs接口被棄用。libgpiod操作gpio的方式感覺更加方便。 但是單板上好像沒裝這個工具&#xff0c;又到了熟悉的交叉編譯環節&#xff08;痛苦&#xff09;。 問題描述 按照流程裝完libgpiod&#xff0c;自信地去交…

安卓Gradle學習與應用:從入門到實踐

引言 在Android開發的世界里&#xff0c;Gradle不僅僅是一個構建工具&#xff0c;它更是一種強大的自動化系統&#xff0c;能夠幫助開發者高效地管理項目依賴、編譯、測試、打包以及部署。本篇博客旨在深入探討Gradle在Android開發中的應用&#xff0c;從基礎概念到實戰技巧&a…