description

luogu

loj(暂无数据)

solution

这道题作为T1,对选手们仔细看清题目的好习惯,以及不为2h调试、5k代码而心态爆炸的重要能力进行了较好的锻炼,

特别准备的只有答案满足\(\le 10^9\)更是让每个同学从此对考场时要仔细看数据范围印象深刻。

实在是出题人良心的馈赠,将为每位选手的oi之路上平添一份助力。

没什么可说的,大力分类讨论+模拟

貌似二分写法会简单很多,不过5k代码丝毫不虚

在此,向该题的出题人表示最诚挚的问候和衷心的祝愿。

code

#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
inline ll read(){
ll x=0,f=1;char ch=getchar();
while(!isdigit(ch)){if(ch=='-') f=-1;ch=getchar();}
while(isdigit(ch)){x=(x<<3)+(x<<1)+(ch^48);ch=getchar();}
return x*f;
}
ll q,r;
int mo_ping[13]={0,31,28,31,30,31,30,31,31,30,31,30,31};
int mo_run[13]={0,31,29,31,30,31,30,31,31,30,31,30,31};
int sum_ping[13],sum_run[13];
inline void calcBC(ll r){
ll zq=366+365+365+365;
ll t=r/zq,p=r%zq;
ll y,m,d;
y=4713-t*4;
if(p>=366+365+365) p-=366+365+365,y-=3;
else if(p>=366+365) p-=366+365,y-=2;
else if(p>=366) p-=366,y-=1;
if(y%4==1){
for(int i=1;i<=12;++i)
if(sum_run[i]>p){m=i;p-=sum_run[i-1];break;}
d=p+1;
}
else{
for(int i=1;i<=12;++i)
if(sum_ping[i]>p){m=i;p-=sum_ping[i-1];break;}
d=p+1;
}
printf("%lld %lld %lld BC\n",d,m,y);
return ;
}
inline void calcjulian(ll r){
ll zq=366+365+365+365;
ll t=r/zq,p=r%zq;
ll y,m,d;
y=4*t+1;
if(p>=365+365+365) p-=365+365+365,y+=3;
else if(p>=365+365) p-=365+365,y+=2;
else if(p>=365) p-=365,y+=1;
if(y%4==0){
for(int i=1;i<=12;++i)
if(sum_run[i]>p){m=i;p-=sum_run[i-1];break;}
d=p+1;
}
else{
for(int i=1;i<=12;++i)
if(sum_ping[i]>p){m=i;p-=sum_ping[i-1];break;}
d=p+1;
}
printf("%lld %lld %lld\n",d,m,y);
return ;
}
inline void calc1582(ll r){
ll y,m,d;
y=1582;
if(r<17) m=10,d=r+15;
else if(r<47) m=11,d=r-16;
else m=12,d=r-46;
printf("%lld %lld %lld\n",d,m,y);
return ;
}
inline void calcbef1600(ll r){
ll y,m,d;
for(int i=1583;i<=1599;++i){
ll ty=i%4?365:366;
if(r<ty){
y=i;
if(y%4==0){
for(int i=1;i<=12;++i)
if(sum_run[i]>r){m=i;r-=sum_run[i-1];break;}
d=r+1;
}
else{
for(int i=1;i<=12;++i)
if(sum_ping[i]>r){m=i;r-=sum_ping[i-1];break;}
d=r+1;
}
break;
}
r-=ty;
}
printf("%lld %lld %lld\n",d,m,y);
return ;
}
int main(){
freopen("julian.in","r",stdin);
freopen("julian.out","w",stdout);
q=read();
for(int i=1;i<=12;++i) sum_ping[i]=sum_ping[i-1]+mo_ping[i],sum_run[i]=sum_run[i-1]+mo_run[i];
ll zq=366+365+365+365;
ll r1=zq*1178; //\xb9\xabԪǰ1\xc4\xea1\xd4\xc21\xc8\xd5
ll r2=r1+366; //\xb9\xabԪ1\xc4\xea1\xd4\xc21\xc8\xd5
ll r3=r2+zq*395+365+sum_ping[9]+3;//\xb9\xabԪ1582\xc4\xea10\xd4\xc24\xc8\xd5
ll r4=r3+1; //\xb9\xabԪ1582\xc4\xea10\xd4\xc215\xc8\xd5
while(q--){
r=read();
if(r<r2) calcBC(r);
else if(r<=r3) calcjulian(r-r2);
else{
r-=r4;
if(r<78) calc1582(r);
else{
ll y,m,d;
r-=78;
ll r5=4*366+13*365;
if(r<r5) calcbef1600(r);
else{
r-=r5;
ll bigzq=97*366+303*365,r6=25*366+75*365,r7=r6*2-1,r8=r6*3-2;
ll t=r/bigzq,p=r%bigzq,zq=366+365*3;
y=1600+t*400;
if(p<r6){
y+=(p/zq)*4;p%=zq;
if(p>=366+365+365) p-=366+365+365,y+=3;
else if(p>=366+365) p-=366+365,y+=2;
else if(p>=366) p-=366,y+=1;
if(y%4==0){
for(int i=1;i<=12;++i)
if(sum_run[i]>p){m=i;p-=sum_run[i-1];break;}
d=p+1;
}
else{
for(int i=1;i<=12;++i)
if(sum_ping[i]>p){m=i;p-=sum_ping[i-1];break;}
d=p+1;
}
printf("%lld %lld %lld\n",d,m,y);
continue;
}
else if(p<r7){
p-=r6;y+=100;
if(p>=365&&p<365+365) p-=365,y++;
else if(p>=365+365&&p<365*3) p-=365*2,y+=2;
else if(p>=365*3&&p<365*4) p-=365*3,y+=3;
else if(p>=365*4){
y+=4;
p-=365*4;
y+=(p/zq)*4;p%=zq;
if(p>=366+365+365) p-=366+365+365,y+=3;
else if(p>=366+365) p-=366+365,y+=2;
else if(p>=366) p-=366,y+=1;
}
if(y%4==0&&y%100!=0){
for(int i=1;i<=12;++i)
if(sum_run[i]>p){m=i;p-=sum_run[i-1];break;}
d=p+1;
}
else{
for(int i=1;i<=12;++i)
if(sum_ping[i]>p){m=i;p-=sum_ping[i-1];break;}
d=p+1;
}
printf("%lld %lld %lld\n",d,m,y);
continue;
}
else if(p<r8){
p-=r7;y+=200;
if(p>=365&&p<365+365) p-=365,y++;
else if(p>=365+365&&p<365*3) p-=365*2,y+=2;
else if(p>=365*3&&p<365*4) p-=365*3,y+=3;
else if(p>=365*4){
y+=4;
p-=365*4;
y+=(p/zq)*4;p%=zq;
if(p>=366+365+365) p-=366+365+365,y+=3;
else if(p>=366+365) p-=366+365,y+=2;
else if(p>=366) p-=366,y+=1;
}
if(y%4==0&&y%100!=0){
for(int i=1;i<=12;++i)
if(sum_run[i]>p){m=i;p-=sum_run[i-1];break;}
d=p+1;
}
else{
for(int i=1;i<=12;++i)
if(sum_ping[i]>p){m=i;p-=sum_ping[i-1];break;}
d=p+1;
}
printf("%lld %lld %lld\n",d,m,y);
continue;
}
else{
p-=r8;y+=300;
if(p>=365&&p<365+365) p-=365,y++;
else if(p>=365+365&&p<365*3) p-=365*2,y+=2;
else if(p>=365*3&&p<365*4) p-=365*3,y+=3;
else if(p>=365*4){
y+=4;
p-=365*4;
y+=(p/zq)*4;p%=zq;
if(p>=366+365+365) p-=366+365+365,y+=3;
else if(p>=366+365) p-=366+365,y+=2;
else if(p>=366) p-=366,y+=1;
}
if(y%4==0&&y%100!=0){
for(int i=1;i<=12;++i)
if(sum_run[i]>p){m=i;p-=sum_run[i-1];break;}
d=p+1;
}
else{
for(int i=1;i<=12;++i)
if(sum_ping[i]>p){m=i;p-=sum_ping[i-1];break;}
d=p+1;
}
printf("%lld %lld %lld\n",d,m,y);
continue;
}
}
}
}
}
return 0;
}

「CSP-S 2020」儒略日的更多相关文章

  1. 「CSP」第一届提高组考后总结

    「CSP」第一届提高组考后总结 问题分析+反思 成绩 心态 考前心态 考时心态 考后心态 方法 心灵鸡汤... 在学习了三年之后,我们信竞迎来了初中最后一次大考,也是第一次 CSPCSPCSP 考试. ...

  2. 「NOIP 2020」微信步数(计数)

    「NOIP 2020」微信步数(Luogu P7116) 题意: 有一个 \(k\) 维场地,第 \(i\) 维宽为 \(w_i\),即第 \(i\) 维的合法坐标为 \(1, 2, \cdots, ...

  3. 深圳即将启动首届「全国人工智能大赛」:超过 500 万大奖 & 政府资助,潜信息你读懂了吗!

    人工智能加速“视频/视觉”发展,近期,深圳市即将迎来人工智能领域权威赛事之一——首届「全国人工智能大赛」(The First National Artificial Intelligence Chal ...

  4. 「CSP-S模拟赛」2019第四场

    「CSP-S模拟赛」2019第四场 T1 「JOI 2014 Final」JOI 徽章 题目 考场思考(正解) T2 「JOI 2015 Final」分蛋糕 2 题目 考场思考(正解) T3 「CQO ...

  5. 迄今为止最硬核的「Java8时间系统」设计原理与使用方法

    为了使本篇文章更容易让读者读懂,我特意写了上一篇<任何人都需要知道的「世界时间系统」构成原理,尤其开发人员>的科普文章.本文才是重点,绝对要读,走起! Java平台时间系统的设计方案 几乎 ...

  6. 「Netty实战 02」手把手教你实现自己的第一个 Netty 应用!新手也能搞懂!

    大家好,我是 「后端技术进阶」 作者,一个热爱技术的少年. 很多小伙伴搞不清楚为啥要学习 Netty ,今天这篇文章开始之前,简单说一下自己的看法: @ 目录 服务端 创建服务端 自定义服务端 Cha ...

  7. 「有数可据」选择IT行业的1000个理由!

    这你要我编 我也编不出一千个呀 现如今转行IT 还需要1000个理由吗? 不 不需要的 一个就好   10月初 CSDN博主「有数可据」 发布了 2020年10月国内程序员薪资情况 他本人是这样说的☟ ...

  8. 「每日一题」面试官问你对Promise的理解?可能是需要你能手动实现各个特性

    关注「松宝写代码」,精选好文,每日一题 加入我们一起学习,day day up 作者:saucxs | songEagle 来源:原创 一.前言 2020.12.23日刚立的flag,每日一题,题目类 ...

  9. 「每日一题」有人上次在dy面试,面试官问我:vue数据绑定的实现原理。你说我该如何回答?

    关注「松宝写代码」,精选好文,每日一题 ​时间永远是自己的 每分每秒也都是为自己的将来铺垫和增值 作者:saucxs | songEagle 来源:原创 一.前言 文章首发在「松宝写代码」 2020. ...

随机推荐

  1. 在java的多态调用中,new的是哪一个类就是调用的哪个类的方法。

    在java的多态调用中,new的是哪一个类就是调用的哪个类的方法.(x) 原因: ava多态有两种情况:重载和覆写 在覆写中,运用的是动态单分配,是根据new的类型确定对象,从而确定调用的方法: 在重 ...

  2. json expected name at 1 1

    问题1:导入新的java项目,报expected name at 1:1错误. 解决方法:勾选Derived复选框.

  3. error: Please reinstall the libzip distribution

    安装中遇到的问题 在运行 ./configure 时,提示: Please reinstall the libzip distribution 是因为 libzip 版本过低,编译升级 先卸载了原先的 ...

  4. 从零造就JVM大牛(一)

    引言 从事java的小伙伴大家好,如果你是一名从事java行业的程序员,无论你是小白还是工作多年的老司机,我相信这篇文章一定会给你带来 不同程度的收货不敢说你看完我的文章从此精通jvm打遍天下无对手, ...

  5. vue 路由工程化重构

    当项目越来越庞大的时候,路由越来越多,而且遍布的页面也越来越多, 当需要更换地址的时候就无比的繁琐,通过学习了解到可以通过router.js来统一调控 原理: 在路由页面通过name来进行跳转,传入的 ...

  6. VMware Workstation Pro 虚拟机安装

    1.简介 虚拟机指通过软件莫比的具体有完整硬件系统功能的.运行在一个完全隔离环境中的完整计算机系统. 我们可以通过虚拟机软件,可以在一台物理计算机模拟出一台或多台虚拟的计算机,这些虚拟的计算机完全就像 ...

  7. 晚间测试13 A. Dove 打扑克 vector +模拟

    题目描述 分析 这道题比较关键的一点就是要看出最终牌数的种类数不会超过 \(\sqrt{n}\) 种 知道了这个性质我们就可以用 \(vector\) 维护一个有序的序列 \(vector\) 中存放 ...

  8. JQuery如何实现统计图表

    EEP JQuery如何实现统计图表 讯光科技 前言 在ERP项目开发过程中,统计图表(chart)普遍应用于各种统计和报表中,其形象直观,内容清晰.EEP的JQuery网站项目使用了Easyui 插 ...

  9. 【总结】java集合

    一.collection 1.List接口和Set接口都继承自Collection接口,Collection接口继承Iterable接口(Iterable有一个Iterator方法),即可迭代的:Co ...

  10. CSS 三栏自适应布局

    CSS布局 这个很基础,方法也很多,要留意的知识点还是有一些. 比如IE6的触发layout  *zoom:1 比如使用浮动后的清除浮动  clear:both 需求的延伸也会有一些: 比如三栏等高 ...