题意:

[3月的第二个周日02:00:00 , 3月的第二个周日03:00:00) 这个区间都不是PST或PDT,[11月的第一个周日01:00:00 , 11月的第一个周日02:00:00) 这个区间既是PST又是PDT,中间的是PDT,两边的是PST。

分析:

计算星期几可以直接用公式进行计算

C/C++ 根据年月日计算星期几——蔡勒公式篇

计算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 根据年月日计算星期的更多相关文章

  1. 08--MOOC--C/C++ 根据年月日计算星期几

    计算任何一天是星期几的几种算法 一:常用公式 W = [Y-1] + [(Y-1)/4] - [(Y-1)/100] + [(Y-1)/400] + D Y是年份数,D是这一天在这一年中的累积天数,也 ...

  2. 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& ...

  3. C# 根据日期计算星期几

    region 根据年月日计算星期几(Label2.Text=CaculateWeekDay(,,);) /// <summary> /// 根据年月日计算星期几(Label2.Text=C ...

  4. hdu 6010 Daylight Saving Time 泰勒公式

    Daylight Saving Time Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Oth ...

  5. Daylight Saving Time

    [Daylight Saving Time] 夏时制,又称日光节约时制.日光節約時間(英语:Daylight saving time)或夏令时间(英语:Summer time),是一种为节约能源而人为 ...

  6. DayLight Saving Light(HDU6010)

    传送门:DayLight Saving Light 夏令时: 夏时令(Daylight Saving Time:DST),又称“日光节约时制”和“夏令时间”,是一种为节约能源而人为规定地方时间的制度, ...

  7. HDU6010 Daylight Saving Time

    /* HDU6010 Daylight Saving Time http://acm.hdu.edu.cn/showproblem.php?pid=6010 模拟 题意:算当前时间是否是夏令时 */ ...

  8. 编写Java程序随机输入日期计算星期几,打印任意一年的日历

    需求说明: 随机输入日期计算星期几,打印任意一年的日历 已知,1900年1月1日是星期1,用户随机输入年月日,计算星期几 实现思路: 一.知道1900年1月1日为星期一,求输入的年份月份与1900年1 ...

  9. 根据日期计算星期几----蔡勒(Zeller)公式推导

    计算给定日期是星期几,好象是编程都会遇到的问题,最近论坛里也有人提到这个问题,并给出了一个公式:             W=   (d+2*m+3*(m+1)/5+y+y/4-y/100+y/400 ...

随机推荐

  1. Java 将Excel转为SVG的方法

    本文以Java示例展示如何将Excel文档转为SVG格式.通过本文中的方法,在将Excel转为SVG时,如果sheet工作表中手动设置了分页,则将每个分页的内容单独保存为一个svg文件,如果sheet ...

  2. java并发编程工具类JUC第二篇:ArrayBlockingQueue

    类ArrayBlockingQueue是BlockingQueue接口的实现类,它是有界的阻塞队列,内部使用数组存储队列元素.这里的"有界"是指存储容量存在上限,不能无限存储元素. ...

  3. html-新闻滚动条

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  4. urllib2连接超时设置

    #urllib2设置超时 #获取网页的源码 def getHtml(url,i): if i > 2: return try: req = urllib2.Request(url) time.s ...

  5. Go基础结构与类型05---程序运算

    package main import ( "fmt" "math" ) func main() { /*加减乘除,求余*/ fmt.Println(" ...

  6. javascript获取日期,年月,日

    <SCRIPT LANGUAGE="JavaScript"> var myDate = new Date();     myDate.getYear();       ...

  7. 使用OneFlow搭建神经网络

    使用OneFlow搭建神经网络 在 识别 MNIST 手写体数字 的例子中,通过 flow.layers 和 flow.nn 中提供的接口搭建了一个简单的 LeNet 网络.下面,将通过LeNet来介 ...

  8. pytorch空间变换网络

    pytorch空间变换网络 本文将学习如何使用称为空间变换器网络的视觉注意机制来扩充网络.可以在DeepMind paper 阅读更多有关空间变换器网络的内容. 空间变换器网络是对任何空间变换的差异化 ...

  9. 常用深度学习框——Caffe/ TensorFlow / Keras/ PyTorch/MXNet

    常用深度学习框--Caffe/ TensorFlow / Keras/ PyTorch/MXNet 一.概述 近几年来,深度学习的研究和应用的热潮持续高涨,各种开源深度学习框架层出不穷,包括Tenso ...

  10. Ryzen 4000'Vermeer' CPU和Radeon RX'Big Navi'图形卡

    Ryzen 4000'Vermeer' CPU和Radeon RX'Big Navi'图形卡 来自中国媒体的多篇报道表明,AMD都准备在2020年第四季度初推出其下一代Ryzen 4000'Zen 3 ...