Giriş
Her zaman PPCG'de ortaya çıkan SBU (Kısa Ama Benzersiz) zorluklarının büyük bir hayranıyım. CUSRS, dizeleri yeniden düzenlemek için tasarlanmış bir sistemdir, CUSRS işlevi 2 parametre alır ve 1 String verir.
Meydan okuma
Aşağıdakileri yapmak için bir program, işlev, lambda veya kabul edilebilir bir alternatif üretin:
Verilen String inputve String refactorrefactor, (örnek olarak) inputkullanılarak refactoraşağıdaki gibi:
refactorString biçiminde olacaktır ((\+|\-)\w* *)+(örneğin düzenli ifade):
+Code -Golf -lf +al
Her bölüm gerçekleştirilecek bir yeniden düzenleme eylemidir input. Her programın da bir işaretçisi vardır.
+ Soneki (artı olmadan) Dize'deki işaretçilerin geçerli konumuna ekler ve ardından işaretçiyi 0'a sıfırlar.
Her işlem Dizeye uygulanmalı inputve sonuç döndürülmelidir.
Misal:
input:
Golf +Code //pointer location: 0
output:
CodeGolf //pointer location: 0
-Soneki bulana kadar işaretçiyi Dize boyunca artırır. Sonek Dize'den kaldırılacak ve işaretçi kaldırılan metnin sol tarafında bırakılacaktır. Herhangi bir sonek bulunmazsa, işaretçi Dize sonuna kadar ilerler ve orada kalır.
input:
Golf -lf //pointer location 0
output:
Go //pointer location 2
Örnekler
input:
"Simple" "-impl +nip -e +er"
output:
"Sniper"
input:
"Function" "-F +Conj"
output:
"Conjunction"
input:
"Goal" "+Code -al +lf"
output:
"CodeGolf"
input:
"Chocolate" "Chocolate"
output:
"Chocolate" //Nothing happens...
input:
"Hello" "-lo+p +Please" //Spaces are irrelevant
output:
"PleaseHelp"
input:
"Mississippi" "-s-s-i-ppi+ng" //Operations can be in any order
output:
"Missing"
input:
"abcb" "-c -b +d"
output:
"abd"
input:
"1+1=2" "-1+22-=2+=23"
outut:
"22+1=23"
Örnek Kod
Örnek Java, hiç golf değil.
public static String refactor(String input, String swap) {
int pointer = 0;
String[] commands = swap.replace(" ", "").split("(?=[-+])");
for (String s : commands) {
if (s.startsWith("+")) {
input = input.substring(0, pointer) + s.substring(1) + input.substring(pointer, input.length());
pointer = 0;
} else {
if (s.startsWith("-")) {
String remove = s.substring(1);
for (int i = pointer; i < input.length(); i++) {
if (input.substring(i, i + remove.length() > input.length() ? input.length() : i + remove.length()).equals(remove)) {
pointer = i;
input = input.substring(0, i) + input.substring(i + remove.length(), input.length());
break;
}
}
}
}
}
return input;
}
kurallar
- Standart Loopholes Uygula
- Bayt cinsinden en kısa kod kazanır
aaa -a?
|aaboru işaretçidir.
-Sonek bulunmazsa ne olur ?