万年历的实现——C++&Java版

最近因为一个题目,然后然后就让用java写一个万年历。然后老夫上午两节课居然没写出来。然后下午就花了一节课写算法。然后逃课进实验室用C++写了一遍。嗯~满满的成就感,开心!

1.C++版万年历

//
//  main.cpp
//  printData
//
//  Created by Ivan小黄 on 18/9/27.
//  Copyright (c) 2018年 ivan. All rights reserved.
//

#include <iostream>
using namespace std;

bool isRun(int year);	
void MatchDays(bool isrun);
int WeekFirstday(int year);
void PrintData(int days[], int startDay);

int * days = new int[12];
int main(int argc, const char * argv[]) {
    int year;
    cout << "请输入一个年份:" << endl;
    cin >> year;
    MatchDays(isRun(year));
    cout << WeekFirstday(year);
    PrintData(days, WeekFirstday(year));
    return 0;
}

void PrintData(int * days, int startDay)	//	打印日历
{
    int index = 0;
    int startday = startDay;
    while (index < 12) {
        cout << "\n\t\t\t第";
        cout <<(index+1);
        cout << "个月\n";
    cout << "星期一\t星期二\t星期三\t星期四\t星期五\t星期六\t星期天\n";
    for (int i = 0; i< startday; i++)
    {
        cout << "\t";
    }
        for (int j = 1; j <= days[index]; j++) {
            cout << j << "\t";
            startday++;
            if(startday >= 7)
            {
                cout << endl;
                startday = 0;
            }
        }
        index++;
    }

}

int WeekFirstday(int year)	//	判断年份开始的星期几
{
    int startDay = 0;
    int days = 0;
    int curYear = 1900;
    for (; curYear < year; curYear++) {
        if(isRun(curYear))
            days += 366;
        else
            days += 365;
    }
    startDay = days % 7;
    return startDay;
}

bool isRun(int year)		//	判断是否为闰年
{
    if((year % 4 == 0 && year % 100 != 0) || year % 400 == 0)
        return true;
    else
        return false;
}

void MatchDays(bool isrun)	//	根据是否为闰年匹配每个月的天数
{
    for (int i = 1; i <= 12; i++) {
        switch (i) {
            case 1:
            case 3:
            case 5:
            case 7:
            case 8:
            case 10:
            case 12:
                days[i-1]=31;
                break;
            case 4:
            case 6:
            case 9:
            case 11:
                days[i-1]=30;
                break;
            case 2:
                if(isrun)
                    days[i-1]=29;
                else
                    days[i-1]=28;
                break;
            default:
                break;
        }
    }
}

2.Java版万年历

算法是一致的。

package javaExcercise_5;
import java.util.Scanner;
public class printData {
	/**
	 * 1900年1月1日是星期一
	 * 打印任意整年的日历
	 * @param args
	 */
static int[] days = new int[12];
public static void main(String[] args){

    int year;
	System.out.println("请输入一个年份:");
	Scanner input = new Scanner(System.in);
	year = input.nextInt();
	MatchDays(isRun(year));
	PrintData(days, WeekFirstday(year));
}

static void PrintData(int[]days, int startDay)
{
	int index = 0;
	int startday = startDay;
	while (index < 12) {
		System.out.print("\n\t\t\t第"+(index + 1)+"个月\n"); 
		System.out.println("星期一\t星期二\t星期三\t星期四\t星期五\t星期六\t星期天"); 
		for (int i = 0; i < startday; i++)
		{
			System.out.print("\t");
		}
		for (int j = 1; j <= days[index]; j++) {
			System.out.print(j + "\t");
			startday++;
			if (startday >= 7)
			{
				System.out.println();
				startday = 0;
			}
		}
		index++;
	}

}

static int WeekFirstday(int year)
{
	int startDay = 0;
	int days = 0;
	int curYear = 1900;
	for (; curYear < year; curYear++) {
		if (isRun(curYear))
			days += 366;
		else
			days += 365;
	}
	startDay = days % 7;
	return startDay;
}

static boolean isRun(int year)
{
	if ((year % 4 == 0 && year % 100 != 0) || year % 400 == 0)
		return true;
	else
		return false;
}

static void MatchDays(boolean isrun)
{
	for (int i = 1; i <= 12; i++) {
		switch (i) {
		case 1:
		case 3:
		case 5:
		case 7:
		case 8:
		case 10:
		case 12:
			days[i - 1] = 31;
			break;
		case 4:
		case 6:
		case 9:
		case 11:
			days[i - 1] = 30;
			break;
		case 2:
			if (isrun)
				days[i - 1] = 29;
			else
				days[i - 1] = 28;
			break;
		default:
			break;
		}
	}
}

}
  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
#include int main (void) { int year,month,j,i,day1,day2,one1,one2,w; printf("enter a year:"); scanf("%d",&year); printf("\n\n"); printf("---------------------%d---------------------\n\n",year); one1=((year-1)*365+(year-1)/4-(year-1)/100+(year-1)/400+1)%7; for(month=1;month<=12;month+=2) { printf(" ",month,year); printf(" \n",month+1,year); printf("-------------------- --------------------\n"); printf("日 一 二 三 四 五 六 日 一 二 三 四 五 六\n"); switch(month) { case 1: case 3: case 5: case 7: case 8: case 10: case 12: day1=31;break; case 4: case 6: case 9: case 11:day1=30;break; default:if(!(year%4)&&(year0)||!(year%400)) day1=29; else day1=28; } for(j=1;j<=one1;j++) { if(one1==7) break; else printf(" "); } for(i=1;i<=7-one1;i++) printf("%2d ",i); printf(" "); switch(month+1) { case 1: case 3: case 5: case 7: case 8: case 10: case 12: day2=31;break; case 4: case 6: case 9: case 11:day2=30;break; default:if(!(year%4)&&(year0)||!(year%400)) day2=29; else day2=28; } one2=(one1+day1)%7; for(j=1;j<=one2;j++) { if(one2==7) break; if(j!=7) printf(" "); } for(i=1;i<=7-one2;i++) printf("%2d ",i); printf("\n"); for(i=8-one1;i<=14-one1;i++) printf("%2d ",i); printf(" "); for(i=8-one2;i<=14-one2;i++) printf("%2d ",i); printf("\n"); for(i=15-one1;i<=21-one1;i++) printf("%2d ",i); printf(" "); for(i=15-one2;i<=21-one2;i++) printf("%2d ",i); printf("\n"); for(i=22-one1;i<=28-one1;i++) printf("%2d ",i); printf(" "); for(i=22-one2;i<=28-one2;i++) printf("%2d ",i); printf("\n"); for(i=29-one1;i<=35-one1&&i<=day1;i++) printf("%2d ",i); printf(" "); for(w=1;w<=35-day1-one1;w++) printf(" "); for(i=29-one2;i<=35-one2&&i<=day2;i++) printf("%2d ",i); printf("\n"); for(i=36-one1;i<=day1;i++) printf("%2d ",i); for(w=1;w<=35-day1-one1;w++) printf(" "); if(day1==31&&(one1==4||one1==3||one1==2||one1==1||one1==7)) printf(" "); if(day1==30&&(one1==4||one1==3||one1==2||one1==1||one1==7)) printf(" "); for(i=36-one2;i<=day2;i++) printf("%2d ",i); printf("\n-------------------- --------------------\n\n"); printf("\n"); one1=(one2+day2)%7; } printf("---------------------%d---------------------\n",year); getchar(); printf("按任意键退出"); getchar(); return 0; }

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值