一道名题-(csp 儒略日)的心得与技巧

这篇具有很好参考价值的文章主要介绍了一道名题-(csp 儒略日)的心得与技巧。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

引:

如果你见到一个oi对着 47131582 146097 2299160 颠颠地笑,不用怀疑,他是在做那道名题--《csp-s2020 T1 儒略日》

这道题,我做了三年,平均每年做一次,我来讲讲我的心得。

读题

题面很长,细节很多,我们需要耐心细心的读,此时多花一点时间是划得来的。

我们得出大致关系如下

\[历法\begin{cases} \begin{aligned} 公历(日常用历)\\ \\ \\ 儒略历 \begin{cases} 公元前\\公元后\\\end{cases} \end{aligned} \end{cases} \]

我们对公历都有一定的了解吧,比如 平年十二个月的天数, 比如小学教的 “一三五七八十腊”,四年一闰百年不闰四百年又闰,这些宝贵的经验将成为我们解题的关键说的呢。

格里高利相较于公历其实更为简单,因为太简单不准所以才改的嘛 ,就是闰年的计算规则不同,是每四年一闰。

解题

首先,这是一道人尽皆知的模拟题。模拟的概念太笼统了,实现起来也八仙过海,我来讲讲我觉得最适合入手这道关于日期的大模拟。

解题的方向

我们要想着化繁为简,一个劲的分类讨论不见得总是好事(我第一次就这么G的)。

多想想在 coding , 写代码的时间总是小于调 bug 的时间的。

我的思路

我们发现,将日期分为儒略历和公历是比较好的,将公元前的日期归化到儒略历的一部分,不用特殊处理,具体来讲,将公元前的日期年份 \(y\) \(->\) \(\ -y + 1\) 比如BC 4713 变为 -4712 ,这阳处理闰年也方便。

我们来算一下儒略历一共多少天

首先公元前天数 365 * 4713 + 4713 / 4

公元后的天数1581 * 365 + 1581 / 4 + 277 1582(不含)年以前的和1582年的277天。

总共 2299160 天。

对于较简单的儒略历,我们可以直接算

int y = -4712, m = 1, d = 1;
    if (x <= Ru) {
        y += x / (_1 * 4 + 1) * 4;
        x %= (_1 * 4 + 1);
        while(x >= (_1 + (y % 4 == 0))) x -= (_1 + (y % 4 == 0)), y++;
        while(x >= (M[m] + (m == 2 && y % 4 == 0))) x -= (M[m] + (m == 2 && y % 4 == 0)), m++;
        d += x;
        if (y < 1) {
            cout << d << ' ' << m << ' ' << 1 - y << ' ' << "BC" << endl;
        } else {
            cout << d << ' ' << m <<' ' << y << endl;
        }
    }

代码中(M[m] + (m == 2 && y % 4 ==0) 是处理闰年的二月日期(28->29)

注意的是, 1 1 4713 BC 是第0天

对于周期的存储,我们可以这样//公历下

int _1 = 365, _4 = 4 * _1 + 1, _100 = 25 * _4 - 1, _400 = _100 * 4 + 1; //100,400是公历下的
int M[13] = {0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};

对于公历, 我们考虑将1582 10 15 到 1982 10 14日这400年打一个小表,这样极大简化了我们的计算量

else {
		x -= Ru;
		y = 0;
		y += x / _400 * 400; x %= _400;
		cout << a[x].d << ' ' << a[x].m << ' ' << y + a[x].y << endl;  
	}

其中a是打出来的表,a[x]是四百年中的第几天,10月15 日算第一天。

那么,怎么打出这个表?

答:用手打 可以用结构体。

struct dt{
	int y, m, d;
	dt(){}
	dt(int _y, int _m, int _d) {
		y = _y, m = _m, d = _d;
	}
}a[maxn], be = {1582, 10, 15};

然后四百年迭代一遍

 dt v = be;
  for (int i = 1; i <= _400; i++) {
  	a[i] = v;
  	nxt(v);
  }

我们只需处理简单的一天的日期跳转

void nxt(dt &x) {
	x.d++;
	if (x.d > (M[x.m] + ck(x))) {
		x.d -= (M[x.m] + ck(x));
		x.m++;
	}
	if (x.m > 12) {
		x.m = 1;
		x.y++;
	}
}

ck 是处理闰年二月

bool ck(dt x) {
	if (x.y % 4 == 0 && x.y % 100 != 0 || x.y % 400 == 0) {
		return x.m == 2;
	} else return 0;
}

于是,我们便做完了这道大模拟。

完结撒花!

没有完!还有您对作者文章的肯定/否定没有留下,可以点赞或留言,作者都会看到!

$Our\ stories\ are\ still\ going\ on.\ $文章来源地址https://www.toymoban.com/news/detail-408358.html

到了这里,关于一道名题-(csp 儒略日)的心得与技巧的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 记一道有趣的sql题

    有一张运单表:dwd_biz_waybill_td,该表的主键是way_bill_id,并且有如下字段: way_bill_id(运单表主键),shiping_date(下单日期,时间格式为yyyy-MM-dd),payment_customer_id(付款客户),damaged_degree_type(是否严重破损,为枚举值。1为是,0为否),is_throw_away(是否丢失,为枚举值。

    2024年02月14日
    浏览(69)
  • BUUCTF刷题十一道(07)

    参考博客 界面源码没有东西,点Source看看 preg_match 正则匹配,结尾用不可见字符绕过 要从 config.php 读 flag , $_SERVER[\\\'PHP_SELF\\\'] 表示的就是当前访问的 php 页面 当我们传入index.php/config.php时,仍然请求的是index.php,但是当basename()处理后,highlight_file()得到的参数就变成了config.p

    2024年02月09日
    浏览(37)
  • [CSP-J 2022] 解密

    大家好,今天我来解题[CSP-J 2022] 解密 题目来源链接 题目描述 给定一个正整数 k k k ,有 k k k 次询问,每次给定三个正整数 n i , e i , d i n_i, e_i, d_i n i ​ , e i ​ , d i ​ ,求两个正整数 p i , q i p_i, q_i p i ​ , q i ​ ,使 n i = p i × q i n_i = p_i times q_i n i ​ = p i ​ × q i ​ 、 e

    2024年02月08日
    浏览(48)
  • CSP 比赛经验分享

    中国软件专业技术资格(水平)考试( CSP-S )是一项旨在评价软件和信息技术 专业人员专业技术水平的考试。对于参加过 CSP 比赛的人来说,这是一个展示 自己编程能力、逻辑思维和解决问题能力的好机会。下面是一些基于个人经验的 CSP 比赛经验分享,希望能帮助到准备参

    2024年04月15日
    浏览(52)
  • 2023CSP-J题解

    烦死了,这次CSP考的真的垃圾,犯了好多低级错误。 小 Y 的桌子上放着 n n n 个苹果从左到右排成一列,编号为从 1 1 1 到 n n n 。 小苞是小 Y 的好朋友,每天她都会从中拿走一些苹果。 每天在拿的时候,小苞都是从左侧第 1 1 1 个苹果开始、每隔 2 2 2 个苹果拿走 1 1 1 个苹果。

    2024年02月08日
    浏览(55)
  • 备考CSP-J—贪心

    额……既然是备考,那么一定要动脑筋,一共5题,大家好好思考一下。 一:P1250 种树 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 二:P1020 [NOIP1999 提高组] 导弹拦截 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn)  三:P1230 智力大冲浪 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 

    2024年01月25日
    浏览(50)
  • CSP-垦田计划

    顿顿总共选中了 n 块区域准备开垦田地,由于各块区域大小不一,开垦所需时间也不尽相同。据估算,其中第 i 块(1≤i≤n)区域的开垦耗时为 ti 天。这 n 块区域可以同时开垦,所以总耗时 tTotal 取决于耗时最长的区域,即:tTotal=max{t1,t2,⋯,tn} 为了加快开垦进度,顿

    2024年02月06日
    浏览(46)
  • CSP-何以包邮?

    新学期伊始,适逢顿顿书城有购书满 x 元包邮的活动,小 P 同学欣然前往准备买些参考书。 一番浏览后,小 P 初步筛选出 n 本书加入购物车中,其中第 i 本(1≤i≤n)的价格为 ai 元。 考虑到预算有限,在最终付款前小 P 决定再从购物车中删去几本书(也可以不删),使得剩

    2024年02月03日
    浏览(34)
  • CSP的理解与绕过

    刚学习完xss,把xsss-labs靶场都通了打算试试水,遇到此题[AFCTF 2021]BABY_CSP,借此机会学习下CSP Content Security Policy (CSP)内容安全策略,是一个附加的安全层,有助于检测并缓解某些类型的攻击,包括跨站脚本(XSS)和数据注入攻击。它实质就是白名单制度,开发者明确告诉客户

    2024年02月10日
    浏览(45)
  • CSP202212-2 训练计划

    西西艾弗岛荒野求生大赛还有 n 天开幕! 为了在大赛中取得好成绩,顿顿准备在 n 天时间内完成“短跑”、“高中物理”以及“核裂变技术”等总共 m 项科目的加强训练。其中第 i 项(1≤i≤m)科目编号为 i,也可简称为科目 i。已知科目 i 耗时 天,即如果从第 a 天开始训练

    2023年04月08日
    浏览(35)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包