你好呀,我是灰小猿,一個超會寫bug的程式猿!
歡迎大家關注我的專欄“每日藍橋”,該專欄的主要作用是和大家分享近幾年藍橋杯省賽及決賽等真題,決議其中存在的演算法思想、資料結構等內容,幫助大家學習到更多的知識和技術!
題目:猜年齡
美國數學家維納(N.Wiener)智力早熟,11歲就上了大學,他曾在1935-1936年應邀來中國清華大學講學,一次,他參加某個重要會議,年輕的臉孔引人注目,于是有人詢問他的年齡,他回答:
“我年齡的立方是個4位數,我年齡的4次方是個六位數,這10個數字正好包含了從0到9這10個數字,每個都恰好出現1次,請你推算一下,他當時到底多年輕,
通過瀏覽器,直接提交他那時的年齡數字,
注意:不要提交解答程序,或其他的說明文字”
答案原始碼:
package 一三年省賽真題;
import java.util.HashSet;
import java.util.Set;
public class One {
public static void main(String[] args) {
//在10歲到100歲之間尋找
for (int i = 10; i < 100; i++) {
int i3 = i*i*i; //獲取到3次方
int i4 = i3*i; //獲取到4次方
String s3 = i3 + "";
String s4 = i4 + "";
//判斷立方的結果是否是4位數,4次方的結果是否是6位數,字符是否是由10個不重復的數字組成
//同時成立則輸出年齡
if (s3.length()==4&&s4.length()==6&&check(s3+s4)) {
System.out.println(i);
}
}
}
/**
* 判斷字符是否是由10個不重復的數字組成
* @param s 判斷的字符
* @return true
* */
private static boolean check(String s) {
Set<Character> set = new HashSet<Character>(); //建立不存放重復字符的集合
// HashSet<String> set = new HashSet<String>();
for (int i = 0; i < s.length(); i++) {
//將字符中的每一個元素單獨拿出存放到集合中,若元素重復則不被存放
set.add(s.charAt(i));
}
return set.size()==10; //字符長度等于10,回傳True
}
}
輸出樣例:
其中有不足或者改進的地方,還希望小伙伴留言提出,一起學習!
感興趣的小伙伴可以關注專欄!
灰小猿陪你一起進步!

轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/246833.html
標籤:java

