[英]Simple output Chinese calendar JAVA | Find an animal + color/type from input
我们有一个输入年份(1987、2015等)和中国日历。 每年有12种动物在变化。 每2年更换5种颜色。 因此,绿猴和绿猴之间的周期为60年。 该周期的第一年是1984年(因此是“绿猴年”)。 我从1984年开始就拥有正确的计数,但是在1984年之前无法提出关于如何正确计算的正确问题。因此,当我输入2005时,一切都很好,而当输入1983时,它就算错了。 所以我的第一个想法和代码是:
public static String getChineseType (int year) {
String answer = "42";
switch (year > 1984 ? (year-1984)%10/2 : SECOND OPTION {
case 0: answer = "Tree/Green"; break;
case 1: answer = "Fire/Red"; break;
case 2: answer = "Earth/Yellow"; break;
case 3: answer = "Metal/White"; break;
case 4: answer = "Water/Black"; break;
default: answer = "Wrong year num"; break;
}
switch (year > 1984 ? (year-1984)%12 : SECOND OPTION {
case 0: answer += " Rat"; break;
case 1: answer += " Ox"; break;
case 2: answer += " Tiger"; break;
case 3: answer += " Rabbit"; break;
case 4: answer += " Dragon"; break;
case 5: answer += " Snake"; break;
case 6: answer += " Horse"; break;
case 7: answer += " Goat"; break;
case 8: answer += " Monkey"; break;
case 9: answer += " Rooster"; break;
case 10: answer += " Dog"; break;
case 11: answer += " Pig"; break;
default: answer += " Wrong year num"; break;
}
return answer;
}
}
那么在没有数组的情况下如何正确编码的最佳方法是什么? 还是应该对> = 1984和<1984使用不同的开关运算符?
(year-1984)%10/2 equals
(year-984)%10/2,
(year-84)%10/2 ,
(year-4)%10/2,
(year+6)%10/2
并且年份> 0
使用查找表 。
首先,您需要摆脱1984年的信息。 仅当猴子出现时,今年才给您: 1984 % 12 = 4
,因此12个周期中的第4年为猴子年。
注意 :这里的12年周期是从0
开始的! 根据1984年是猴子的信息,我们可以得出那是0
年的动物。 我们的循环计数器与猴子无关是第一件事。
现在,您可以创建查找表:
private final static Map<Integer, String> ANIMAL_YEARS = new HashMap<Integer, String>(){{
//Check the actual values!!
put(0, "Rat");
put(1, "Ox");
put(2, "Tiger");
...
put(11, "Pig");
}};
现在要获得动物,您只需致电:
String animal = ANIMAL_YEARS.get(year%12);
颜色可以相同:
private final static Map<Integer, String> COLOR_YEARS = new HashMap<Integer, String>(){{
//Check the actual values!!
put(0, "Tree/Green");
put(2, "Fire/Red");
put(4, "Earth/Yellow");
...
put(8, "Water/Black");
}};
那么你也能:
int decimal = year % 10;
String color = COLOR_YEARS.get(decimal%2==1?decimal-1:decimal);
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.