zoukankan      html  css  js  c++  java
  • POJ

    //poj 2080
    //题目大意:给定天数,从2000年1月1日经过这些天后的 年 月 日 及 星期几
    //代码参照大牛的写的,本人还是处于菜鸟阶段,思路很好
    #include<stdio.h> #include<string.h> #include<stdlib.h> #include<ctype.h> #include<math.h> #include<algorithm> using namespace std; #define N 1100 int IsLeap(int y) { return ((y%4==0&&y%100!=0) || (y%400==0)); } int main() { int n, ansy, ansm, ansd, answ; int tab[2][13]={{0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31}, {0, 31, 29, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31}}; char s[7][10]={{"Saturday"}, {"Sunday"}, {"Monday"}, {"Tuesday"}, {"Wednesday"}, {"Thursday"}, {"Friday"}}; while(scanf("%d", &n), n!=-1) { ansy=2000; ansm=1; ansd=1; answ=n%7; while(n) { if(IsLeap(ansy)) { if(n>=366) { n-=366; ansy++; } else { if(n>=tab[IsLeap(ansy)][ansm]) { n-=tab[IsLeap(ansy)][ansm]; ansm++; } else { ansd+=n; n=0; } } } else { if(n>=365) { n-=365; ansy++; } else { if(n>=tab[IsLeap(ansy)][ansm]) { n-=tab[IsLeap(ansy)][ansm]; ansm++; } else { ansd+=n; n=0; } } } } printf("%d-%02d-%02d %s ", ansy, ansm, ansd, s[answ]); } return 0; }
  • 相关阅读:
    注册表命令大全(二)
    让电脑定时关机
    NSIS nsDialogs 插件
    poj_1562Oil Deposits
    hdoj_1342Lotto
    VS 生成事件文件拷贝
    poj_1111Image Perimeters
    模拟求解迷宫问题(DFS+BFS)
    VS2010如何为所有工程配置环境
    POJ 并查集 题目汇总 ——czyuan原创
  • 原文地址:https://www.cnblogs.com/9968jie/p/5417531.html
Copyright © 2011-2022 走看看