蓝桥杯——第十二届国赛——完全日期

完全日期
本题总分:10 分

问题描述

  如果一个日期中年月日的各位数字之和是完全平方数,则称为一个完全日期。
  例如:2021 年 6 月 5 日的各位数字之和为 2+0+2+1+6+5=16,而 16 是一个完全平方数,它是 4 的平方。所以 2021 年 6 月 5 日是一个完全日期。
  例如:2021 年 6 月 23 日的各位数字之和为 2+0+2+1+6+2+3=16,是一个完全平方数。所以 2021 年 6 月 23 日也是一个完全日期。
  请问,从 2001 年 1 月 1 日到 2021 年 12 月 31 日中,一共有多少个完全日期?

答案提交

  这是一道结果填空的题,你只需要算出结果后提交即可。本题的结果为一个整数,在提交答案时只填写这个整数,填写多余的内容将无法得分。


代码如下:

public class Main {
	static int sum=0;
	public static void main(String[] args) {
		for (int i = 2001; i <= 2021; i++) {
			for (int j = 1; j <= 12; j++) {
				if(i%4==0&&i%100!=0||i%400==0) {//闰年
					if(j==1||j==3||j==5||j==7||j==8||j==10||j==12) {
						for (int j2 = 1; j2 <= 31; j2++) {
							String a=""+i+j+j2;
							char b=0;
							for (int k = 0; k < a.length(); k++) {
								b+=a.charAt(k)-48;
							}
							int c=(int) b;
							if((int)Math.sqrt(c)*(int)Math.sqrt(c)==c) {
								sum++;
								System.out.print(i);
								System.out.print(j);
								System.out.println(j2);
							}
						}
					}else
					if(j==2) {
						for (int j2 = 1; j2 <= 29; j2++) {
							String a=""+i+j+j2;
							char b=0;
							for (int k = 0; k < a.length(); k++) {
								b+=a.charAt(k)-48;
							}
							double c=(double) b;
							if((int)Math.sqrt(c)*(int)Math.sqrt(c)==c) {
								System.out.print(i);
								System.out.print(j);
								System.out.println(j2);
								sum++;
							}
						}
					}else {
						for (int j2 = 1; j2 <= 30; j2++) {
							String a=""+i+j+j2;
							char b=0;
							for (int k = 0; k < a.length(); k++) {
								b+=a.charAt(k)-48;
							}
							double c=(double) b;
							if((int)Math.sqrt(c)*(int)Math.sqrt(c)==c) {
								System.out.print(i);
								System.out.print(j);
								System.out.println(j2);
								sum++;
							}
						}
					}
				}else {//平年
					if(j==1||j==3||j==5||j==7||j==8||j==10||j==12) {
						for (int j2 = 1; j2 <= 31; j2++) {
							String a=""+i+j+j2;
							char b=0;
							for (int k = 0; k < a.length(); k++) {
								b+=a.charAt(k)-48;
							}
							double c=(double) b;
							if((int)Math.sqrt(c)*(int)Math.sqrt(c)==c) {
								System.out.print(i);
								System.out.print(j);
								System.out.println(j2);
								sum++;
							}
						}
					}else
					if(j==2) {
						for (int j2 = 1; j2 <= 28; j2++) {
							String a=""+i+j+j2;
							char b=0;
							for (int k = 0; k < a.length(); k++) {
								b+=a.charAt(k)-48;
							}
							double c=(double) b;
							if((int)Math.sqrt(c)*(int)Math.sqrt(c)==c) {
								System.out.print(i);
								System.out.print(j);
								System.out.println(j2);
								sum++;
							}
						}
					}else {
						for (int j2 = 1; j2 <= 30; j2++) {
							String a=""+i+j+j2;
							char b=0;
							for (int k = 0; k < a.length(); k++) {
								b+=a.charAt(k)-48;
							}
							double c=(double) b;
							if((int)Math.sqrt(c)*(int)Math.sqrt(c)==c) {
								System.out.print(i);
								System.out.print(j);
								System.out.println(j2);
								sum++;
							}
						}
					}
				}
			}
		}
		System.out.println(sum);
	}
}

你可能感兴趣的:(蓝桥杯,蓝桥杯,java,算法)