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 ...
随机推荐
- tail -n 10 /etc/passwd
# tail -n 10 /etc/passwdrpc:x:32:32:Rpcbind Daemon:/var/lib/rpcbind:/sbin/nologinchrony:x:992:987::/ ...
- IT菜鸟之网线制作
网线是属于OSI七层模型中的物理层:网络中的数据传输媒介 备注:OSI七层模型后面会记录 网线制作所需要的资源素材: 1.网线 2.水晶头(类型:电话线RJ11,宽带线RJ45) 3.网线钳(非必需) ...
- python基础之列表、元组
一.列表 列表(list)是我们最以后最常用的数据类型之一,通过列表可以对数据实现最方便的存储.修改等操作 作用:多个装备,多个爱好,多门课程,多个女朋友等 定义:[ ]内可以有多个任意类型的值,逗号 ...
- Linux Socket编程-(转自吴秦(Tyler))
"一切皆Socket!" 话虽些许夸张,但是事实也是,现在的网络编程几乎都是用的socket. --有感于实际编程和开源项目研究. 我们深谙信息交流的价值,那网络中进程之间如何通信 ...
- 发现新大陆 --21lic
21lic网上发单平台 http://project.21ic.com/p/97250
- 基于Jira的运维发布平台的设计与实现
作者:乔克 公众号:运维开发故事 上线发布是运维的日常工作,常见的发布方式有: 手动发布 Jenkins发布平台 Gitlab CI ...... 除此之外还有需要开源软件,他们都有非常不错的发布管理 ...
- 聊聊java工程师换工作那些事
最近有个读者在苦恼一件事,那就是有大公司在挖他,他要不要从所在的小公司,跳槽到大公司,前提是两家公司的待遇基本一致.由这个问题结合自己多年的工作经验,来谈谈java工程师要不要跳槽,何时跳槽,怎么跳槽 ...
- Step By Step(Lua环境)
Step By Step(Lua环境) Lua将其所有的全局变量保存在一个常规的table中,这个table被称为"环境".它被保存在全局变量_G中. 1. 全局变量声明: ...
- Go基础结构与类型05---程序运算
package main import ( "fmt" "math" ) func main() { /*加减乘除,求余*/ fmt.Println(" ...
- lms框架模块详解
模块的定义 一般地,开发者如果想要在一个自定义的程序集(包)中注册相关的服务,或者在应用初始化或停止时执行一段自定义的代码,那么您可能需要将该程序集(包)定义为一个模块. lms框架存在两种类型的模块 ...