別在年底突擊發貨,馬斯克敦促特斯拉員工降低交車成本
阿新 • • 發佈:2021-11-28
給定一個正整數 n ,輸出外觀數列的第 n 項。
「外觀數列」是一個整數序列,從數字 1 開始,序列中的每一項都是對前一項的描述。
你可以將其視作是由遞迴公式定義的數字字串序列:
countAndSay(1) = "1"
countAndSay(n) 是對 countAndSay(n-1) 的描述,然後轉換成另一個數字字串。
前五項如下:
-
1
-
11
-
21
-
1211
-
111221
第一項是數字 1
描述前一項,這個數是 1 即 “ 一 個 1 ”,記作 "11"
描述前一項,這個數是 11 即 “ 二 個 1 ” ,記作 "21"
描述前一項,這個數是 21 即 “ 一 個 2 + 一 個 1 ” ,記作 "1211"
描述前一項,這個數是 1211 即 “ 一 個 1 + 一 個 2 + 二 個 1 ” ,記作 "111221"
要 描述 一個數字字串,首先要將字串分割為 最小 數量的組,每個組都由連續的最多 相同字元 組成。然後對於每個組,先描述字元的數量,然後描述字元,形成一個描述組。要將描述轉換為數字字串,先將每組中的字元數量用數字替換,再將所有描述組連線起來。
來源:力扣(LeetCode)
連結:https://leetcode-cn.com/problems/count-and-say
著作權歸領釦網路所有。商業轉載請聯絡官方授權,非商業轉載請註明出處。
心之所向,素履以往 生如逆旅,一葦以航import java.util.Scanner; class Solution { private static String[] nums; private static String solve(String str) { StringBuilder sb = new StringBuilder(); int count = 1; for (int i = 1; i < str.length(); ++i) { if (str.charAt(i) == str.charAt(i - 1)) { count++; } else { sb.append(count).append(str.charAt(i-1)); count = 1; } } sb.append(count).append(str.charAt(str.length() - 1)); return sb.toString(); } static { nums = new String[30]; nums[0] = "1"; for (int i = 1; i < nums.length; ++i) { nums[i] = solve(nums[i - 1]); } } public static String countAndSay(int n) { return nums[n - 1]; } public static void main(String[] args) { Scanner in = new Scanner(System.in); while (in.hasNext()) { System.out.println(countAndSay(in.nextInt())); } } }