码迷,mamicode.com
首页 > 其他好文 > 详细

OJ刷题---1.1.3 Friday the Thirteenth 黑色星期五

时间:2015-08-30 23:08:04      阅读:195      评论:0      收藏:0      [点我收藏+]

标签:c++   博客   数据   算法   iostream   

 题目要求:

技术分享


输入代码:

#include<iostream>
#include<stdio.h>
#include<cstdlib>
using namespace std;
int month[13]= {0,31,28,31,30,31,30,31,31,30,31,30,31};
int ans[8]= {0};
int n,end;
void work(int n)
{
    int y,m,d,i;
    int w=1;
    y=1900;
    end=y+n-1;
    m=d=1;
    while(y!=end||m!=12||d!=31)//到end年12月31日退出循环
    {
        if(d==month[m]+1)//表示到月底,换下一月
        {
            d=1;
            m++;
        }
        if(m==13)//表示到12月份,到下一年
        {
            y++;
            m=1;
        }
        if((y%100!=0&&y%4==0)||y%400==0)//闰年的二月
        {
            month[2]=29;
        }
        else
        {
            month[2]=28;
        }
        if(d==13)//13号
        {
            ans[w]++ ;//13号在该周的次数加1
        }
        w ++ ;
        w = (w - 1 ) % 7 + 1 ;//表示周几
        d ++ ;
    }
    cout<<ans[6]<<" "<<ans[7]<<" ";
    for(i=1; i<=4; i++)
    {
        cout<<ans[i]<<" ";
    }
    cout<<ans[5]<<endl;
}
int main()
{
    //freopen( "friday.in" ," r " ,stdin);
    //freopen( "friday.out" ," w " ,stdout);
    cin>>n;
    work(n);
    //fclose(stdin);//关闭文件
    //fclose(stdout);//关闭文件
    return 0;
}






运行结果:

技术分享


版权声明:本文为博主原创文章,未经博主允许不得转载。

OJ刷题---1.1.3 Friday the Thirteenth 黑色星期五

标签:c++   博客   数据   算法   iostream   

原文地址:http://blog.csdn.net/linhaiyun_ytdx/article/details/48111259

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!