找回密码
 注册
搜索
热搜: 回贴
  • 前程无忧官网首页 有什么好的平台可以
  • 最新的销售平台 互联网营销的平台有哪
  • 制作网页的基本流程 网页制作和网页设
  • 【帝国CMS】输出带序号的列表(数字排
  • 网站建设公司 三一,中联,极东泵车的
  • 织梦 建站 织梦网站模版后台怎么更改
  • 云服务官网 哪些网站有免费的简历模板
  • 如何建网站要什么条件 建网站要用什么
  • 吉林市移动公司电话 吉林省退休人员网
  • 设计类毕业论文 网站设计与实现毕业论
查看: 1417|回复: 0

全年版万年历,请高手指教

[复制链接]
发表于 2009-11-5 00:57:23 | 显示全部楼层 |阅读模式 IP:江苏扬州
//全年版万年历源代码
#include <iostream.h>
#include <iomanip.h>
#include <windows.h>
#include <math.h>
int week (int y, int m, int d) //日期转换星期的函数,返回0是周一,1是周二,以此类推,6是周日   
{
    if (m==1||m==2)  y=y-1,m=m+12;
    return ((d+2*m+3*(m+1)/5+y+y/4-y/100+y/400)%7);
}
bool leap(int y) //判断是否闰年
{
    return ((y%4==0&&y%100!=0)||(y%400==0));
}
int Day (int year,int month) //计算某月天数
{
    int day;
    bool leap(int y);
    if (month==4||month==6||month==9||month==11) day=30;
    else
        if(month==2)
            if(leap(year)==1) day=29;
            else day=28;
        else day=31;
    return day;
}
void print( int y,int m,int d)  //输出控制函数
{
    int a,t;
    int week (int y, int m, int d);
    int Day (int year,int month);
    t=week(y,m,d);
    if(d<=Day(y,m))
    {
    if(d==1)
    {
        for(a=1;a<=3*t;a++) cout<<" ";
        cout<<setw(2)<<d<<" ";
    }
    else cout<<setw(2)<<d<<" ";
    if(t==6)
    {
        if(m%3==0) cout<<"*"<<endl;
        else cout<<"* ";
    }
    if(d==Day(y,m)&&t!=6)
    {
        for(a=1;a<=abs(t-6)*3;a++) cout<<" ";
        if (m%3==0) cout<<"*"<<endl;
        else cout<<"* ";
    }
    }
    else if(t==6) cout<<"                     * ";
}
void main()
{
    int year,month,i,j,k;
    char c;
    int week (int,int,int);
    void print(int,int,int);
        int Day (int,int);
        N:cout<<" 请输入年份:";
    cin>>year;
    if(year<0) goto N;
    system("cls");
    cout<<"                                公元"<<year<<"年                          "<<endl;
    cout<<endl<<"** ** ** ** ** ** ** * ** ** ** ** ** ** ** * ** ** ** ** ** ** ** *"<<endl;
    for(month=1;month<=12;month=month+3)
    {
        j=0;
        k=0;
        if(month<10) cout<<"         "<<month<<"月         *          "<<month+1<<"月         *          "<<month+2<<"月         *         "<<endl;
        else cout<<"         "<<month<<"月        *          "<<month+1<<"月        *          "<<month+2<<"月        *         "<<endl;
        cout<<"                     *                      *                      *"<<endl;
        cout<<"一 二 三 四 五 六 七 * 一 二 三 四 五 六 七 * 一 二 三 四 五 六 七 *"<<endl;
        for (i=1;i<=35;i++)
        {
            print(year,month,i);
            if(week(year,month,i)==6||i==Day(year,month))
            {
                j++;
                for (;j<=35;j++)
                {
                    print(year,month+1,j);
                    if(week(year,month+1,j)==6||j==Day(year,month+1))
                    {
                        k++;
                        for(;k<=35;k++)
                        {
                            print(year,month+2,k);
                            if(week(year,month+2,k)==6||k==Day(year,month+2)) break;
                        }
                        break;
                    }
                }
            }
        }
        cout<<endl<<"** ** ** ** ** ** ** * ** ** ** ** ** ** ** * ** ** ** ** ** ** ** *"<<endl;
    }
    while(1)
    {
        cout<<endl<< "重新输入(1)|退出(2):";
        cin>>c;
        if(c=='1') goto N;
        if(c=='2') break;
    }
}
效果截图
您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|小黑屋|最新主题|手机版|微赢网络技术论坛 ( 苏ICP备08020429号 )

GMT+8, 2024-11-6 03:12 , Processed in 0.783245 second(s), 12 queries , Gzip On, MemCache On.

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表