Java 7、725バイト
f(int)(325バイト):
String f(int i){String s="";for(int j=0,e=0;e<i;e+=v(s))s=Integer.toBinaryString(j++);return"["+s.replace("1","[").replace("0","]")+"]";}int v(String s){for(;!s.isEmpty();s=s.replaceFirst("1","").replaceFirst("0",""))if(s.replace("1","").length()!=s.replace("0","").length()|s.charAt(0)<49|s.endsWith("1"))return 0;return 1;}
g(String)(75 + 325バイト):
int g(String s){int r=0;for(String i="10";!i.equals(s);i=f(++r));return r;}
method gはmethod fを使用して、入力されたものに等しいものが見つかるまで、可能性のあるvoidリストをループすることで結果を計算しますf。
説明:
一般に、メソッドfは整数のすべてのバイナリ文字列表現をループし、有効なものが見つかるたびにカウンタを増やします。有効なバイナリ文字列この挑戦のために、以下の規則に従わ:彼らはで始まり1、で終わり0。それらは同じ数の1と0を持っています。あなたが最初に削除するたびに1と0と検証が再び残っているものは、これらの2つのルールが適用されます。カウンタが入力と等しくなった後、すべて1を[とで置き換えることにより、そのバイナリ文字列を文字列voidリストに変換します0をでし]ます。
メソッドgについては、"[]"(void-listを表す0)で開始しf、整数を増やしながらinput-Stringに一致するまでmethod を使用し続けます。
String f(int i){ // Method `f` with integer parameter and String return-type
String s=""; // Start with an empty String
for(int j=0,e=0;e<i; // Loop as long as `e` does not equal the input
e+=v(s)) // And append increase integer `e` if String `s` is valid
s=Integer.toBinaryString(j++);
// Change `s` to the next byte-String of integer `j`
// End of loop (implicit / single-line body)
return"["+ // Return the result String encapsulated in "[" and "]"
s.replace("1","[").replace("0","]")+"]";
// after we've replaced all 1s with "[" and all 0s with "]"
} // End of method `f`
int v(String s){ // Separate method with String parameter and integer return-type
for(;!s.isEmpty(); // Loop as long as String `s` isn't empty
s=s.replaceFirst("1","").replaceFirst("0",""))
// After each iteration: Remove the first "1" and "0"
if(s.replace("1","").length()!=s.replace("0","").length()
// If there isn't an equal amount of 1s and 0s
|s.charAt(0)<49 // or the String doesn't start with a 1
|s.endsWith("1")) // or the String doesn't end with a 0
return 0; // Return 0 (String is not valid)
// End of loop (implicit / single-line body)
return 1; // Return 1 (String is valid)
} // End of separate method
int g(String s){ // Method `g` with String parameter and integer return-type
int r=0; // Result integer
for(String i="[]";!i.equals(s);
// Loop as long as `i` does not equal the input String
i=f(++r)); // After each iteration: Set `i` to the next String in line
return r; // Return the result integer
} // End of method `g`
入出力の例:
ここで試してみてください。(注:最後のいくつかのテストケースではかなり遅くなります。すべてのテストケースで約10〜15秒かかります。)
0 <-> []
1 <-> [[]]
2 <-> [[][]]
3 <-> [[[]]]
4 <-> [[][][]]
5 <-> [[][[]]]
6 <-> [[[]][]]
7 <-> [[[][]]]
8 <-> [[[[]]]]
9 <-> [[][][][]]
10 <-> [[][][[]]]
11 <-> [[][[]][]]
12 <-> [[][[][]]]
13 <-> [[][[[]]]]
14 <-> [[[]][][]]
50 <-> [[[][[[]]]]]
383 <-> [[[][]][[[][]]]]