Gym 101206L Daylight Saving Time 根据年月日计算星期
题意:
[3月的第二个周日02:00:00 , 3月的第二个周日03:00:00) 这个区间都不是PST或PDT,[11月的第一个周日01:00:00 , 11月的第一个周日02:00:00) 这个区间既是PST又是PDT,中间的是PDT,两边的是PST。
分析:
计算星期几可以直接用公式进行计算
计算3月的第二个周日为哪一天:day=15-ReturnWeekDay(year,3,1)
计算11月的第一个周日为哪一天:day=8-ReturnWeekDay(year,11,1)
这个公式可以自行推导
#include <bits/stdc++.h>
using namespace std; char s[50]; struct Time
{
int mth,day;
int hor,mnt,scd;
Time() {};
Time(int m,int d,int h,int mi,int s)
{
mth=m,day=d;
hor=h,mnt=mi,scd=s;
}
} ti; int ReturnWeekDay( unsigned int iYear, unsigned int iMonth, unsigned int iDay )
{ //http://blog.csdn.net/areskris/article/details/8661983
int iWeek=0;
unsigned int y=0, c=0, m=0, d=0;
if(iMonth==1 || iMonth==2 )
{
c=( iYear-1)/ 100;
y=( iYear-1)% 100;
m=iMonth+12;
d=iDay;
}
else
{
c=iYear/100;
y=iYear%100;
m=iMonth;
d=iDay;
}
iWeek=y+y/4+c/4-2*c+26*(m+1)/10+d-1; //蔡勒公式
iWeek=iWeek >= 0 ?(iWeek % 7):(iWeek%7+7); //iWeek为负时取模
if(iWeek==0) iWeek=7; //星期日不作为一周的第一天
return iWeek;
} int circle(int k)
{
int res=0;
for(int i=k; i<k+2; i++)
{
res*=10;
res+=s[i]-'0';
}
return res;
} void transf()
{
ti.mth=circle(5);
ti.day=circle(8);
ti.hor=circle(11);
ti.mnt=circle(14);
ti.scd=circle(17);
} bool cmp(Time a,Time b)
{
if(a.mth==b.mth)
{
if(a.day==b.day)
{
if(a.hor==b.hor)
{
if(a.mnt==b.mnt)
{
return a.scd<b.scd? false:true;
}
return a.mnt<b.mnt? false:true;
}
return a.hor<b.hor? false:true;
}
return a.day<b.day? false:true;
}
return a.mth<b.mth? false:true;
} int main()
{
// freopen("in.txt","r",stdin);
int t,kase=0;
scanf("%d",&t);
getchar();
while(t--)
{
gets(s);
transf();
int year=0;
for(int i=0; i<4; i++)
{
year*=10;
year+=s[i]-'0';
}
int day=15-ReturnWeekDay(year,3,1);
Time pst1=Time(3,day,2,0,0);
Time pdt1=Time(3,day,3,0,0);
day=8-ReturnWeekDay(year,11,1);
Time pdt2=Time(11,day,1,0,0);
Time pst2=Time(11,day,2,0,0);
printf("Case #%d: ",++kase);
if(!cmp(ti,pst1) || cmp(ti,pst2))
puts("PST");
else if(cmp(ti,pst1) && !cmp(ti,pdt1))
puts("Neither");
else if(cmp(ti,pdt1) && !cmp(ti,pdt2))
puts("PDT");
else puts("Both");
}
return 0;
}
Gym 101206L Daylight Saving Time 根据年月日计算星期的更多相关文章
- 08--MOOC--C/C++ 根据年月日计算星期几
计算任何一天是星期几的几种算法 一:常用公式 W = [Y-1] + [(Y-1)/4] - [(Y-1)/100] + [(Y-1)/400] + D Y是年份数,D是这一天在这一年中的累积天数,也 ...
- An problem about date 根据年月日计算 星期几
/W = (d+2*m+3*(m+1)/5+y+y/4-y/100+y/400) mod 7(1.2月需要看作上一年的13.14月) #include<stdio.h> #include& ...
- C# 根据日期计算星期几
region 根据年月日计算星期几(Label2.Text=CaculateWeekDay(,,);) /// <summary> /// 根据年月日计算星期几(Label2.Text=C ...
- hdu 6010 Daylight Saving Time 泰勒公式
Daylight Saving Time Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Oth ...
- Daylight Saving Time
[Daylight Saving Time] 夏时制,又称日光节约时制.日光節約時間(英语:Daylight saving time)或夏令时间(英语:Summer time),是一种为节约能源而人为 ...
- DayLight Saving Light(HDU6010)
传送门:DayLight Saving Light 夏令时: 夏时令(Daylight Saving Time:DST),又称“日光节约时制”和“夏令时间”,是一种为节约能源而人为规定地方时间的制度, ...
- HDU6010 Daylight Saving Time
/* HDU6010 Daylight Saving Time http://acm.hdu.edu.cn/showproblem.php?pid=6010 模拟 题意:算当前时间是否是夏令时 */ ...
- 编写Java程序随机输入日期计算星期几,打印任意一年的日历
需求说明: 随机输入日期计算星期几,打印任意一年的日历 已知,1900年1月1日是星期1,用户随机输入年月日,计算星期几 实现思路: 一.知道1900年1月1日为星期一,求输入的年份月份与1900年1 ...
- 根据日期计算星期几----蔡勒(Zeller)公式推导
计算给定日期是星期几,好象是编程都会遇到的问题,最近论坛里也有人提到这个问题,并给出了一个公式: W= (d+2*m+3*(m+1)/5+y+y/4-y/100+y/400 ...
随机推荐
- 什么是环境变量,Linux环境变量及作用 echo
什么是环境变量,Linux环境变量及作用 < Linux命令的执行过程是怎样的?(新手必读)Linux PATH环境变量是什么,有什么用?(入门必读) > <Linux就该这么学&g ...
- 6T硬盘分区
6T硬盘分区 1.umount /data1 # 如果正在使用需要此命令卸载. 2.parted /dev/sdb # parted 分区工具,选择要分区的硬件设备 mklabel gp ...
- IT菜鸟之路由器基础配置(静态、动态、默认路由)
路由器:连接不同网段的设备 企业级路由和家用级路由的区别: 待机数量不同(待机量) 待机量:同时接通的终端设备的数量 待机量的值越高,路由的性能越好 别墅级路由,表示信号好,和性能无关 交换机:背板带 ...
- linux初级之总结复习
一.linux命令复习 1.ls:列出当前目录下的文件 -h: -l: -d: -a: 2. man: 命令帮助手册 3. cd: 切换目录 -: ~: ..: cd: 4. pwd: 显示当前工作 ...
- 使用Mybatis插件 PageHelper 模拟百度分页(Day_20)
生活中,要学会沉淀生命,沉淀心情,沉淀自己 模拟百度分页最终实现效果如图: 本篇博客运行环境 JDK8 + IntelliJ IDEA 2018.3 + Tomcat 8.5.31 准备好了我们就开始 ...
- 「 刘一哥与GIS的故事 」专业技术博文专栏目录索引
刘一哥,多年研究地图学.地理信息系统.遥感.摄影测量和GPS等应用,精通ArcGIS.MapGIS.ENVI.Erdas.CASS.Pix4d.CC.PhotoScan.Inpho.EPS.Globa ...
- 安卓开发(2)—— Kotlin语言概述
安卓开发(2)-- Kotlin语言概述 Android的官方文档都优先采用Kotlin语言了,学它来进行Android开发已经是一种大势所趋了. 这里只讲解部分的语法. 如何运行Kotlin代码 这 ...
- Django基本文件配置
1.setting.py (1) ALLOWED_HOSTS = ['*'] (2) INSTALLED_APPS = ['app_name'] (3) TEMPLATES 中的 'DIRS': ...
- 查看mysql的数据库物理存放位置
1.查看mysql的数据库物理存放位置: show global variables like "%datadir%";
- GO文件读写01---读文件
打开文件 package main import ( "fmt" "os" ) /* buffer 缓冲区 utility 便利的工具 util 便捷工具(傻瓜 ...