Java, 318 312 297 294 260 258 bayt
Cliffot sayesinde 15 bayt kurtarıldı !
interface a{static void main(String[]A){int b=Byte.valueOf(A[0]),B=Byte.valueOf(A[1]),C=3+b*2;String c="";if(b<2&B<2)c="o";else{for(;C-->0;)c+="_";for(;B-->0;){c+="\n|";for(C=b;C-->0;)c+=" o";c+=" |";}c+="\n";for(C=3+b*2;C-->0;)c+="-";}System.out.print(c);}}
Komut satırı argümanları ile çalışır.
Ungolfed İnsan tarafından okunabilir bir biçimde:
interface a {
static void main(String[] A) {
int b = Byte.valueOf(A[0]),
B = Byte.valueOf(A[1]),
C = 3 + b*2;
String c = "";
if (b < 2 & B < 2)
c = "o";
else {
for (; C-- > 0;)
c += "_";
for (; B-- > 0;) {
c += "\n|";
for (C = b; C-- >0;)
c += " o";
c += " |";
}
c += "\n";
for(C = 3 + b*2; C-- >0;)
c += "-";
}
System.out.print(c);
}
}
Evet, program kurulduysa bile neler olduğunu anlamak hala zor. İşte adım adım açıklama:
static void main(String[] A)
İlk iki komut satırı argümanı - boyutları elde etmek için kullanacağımız - programda A[0]
ve A[1]
sırasıyla kullanılabilir.
int b = Byte.valueOf(A[0]),
B = Byte.valueOf(A[1]),
C = 3 + b*2;
String c = "";
b
sütun B
sayısıdır, satır sayısıdır ve döngülerde C
kullanım için ayrılmış bir değişkendir for
.
c
Lego parçası. Buna satır ekleriz ve sonunda yazdırırız.
if (b < 2 & B < 2)
c = "o";
else {
Basılacak parça 1x1 ise, hem b
(sütun sayısı) ve B
biz sadece set Yani (satır sayısı) daha küçük 2 olması gereklidir c
tek için o
ve sonra atlamak için açıklamada System.out.print
eğer olay buysa parça bu.
for (; C-- > 0; C)
c += "_";
Burada, (integerValueOfA[0] * 2) + 3
altını çizeriz c
. Bu, tüm deliklerin üstündeki en üst sıradır.
for (; B > 0; B--) {
c += "\n|";
for(C = b; C-- > 0;)
c+=" o";
c += " |";
}
Bu, parçayı her seferinde bir satır yaptığımız döngüdür. İçeride neler olup bittiğini örnek olmadan açıklamak mümkün değil. Diyelim ki parça 4x4:
Before entering the loop, c looks like this:
___________
After the first iteration (\n denotes a line feed):
___________\n
| o o o o |
After the second iteration:
___________\n
| o o o o |\n
| o o o o |
After the third iteration:
___________\n
| o o o o |\n
| o o o o |\n
| o o o o |
.
c += "\n";
for (C = 3 + b*2; C-- > 0;)
c += "-";
Burada, (integerValueOfA[0] * 2) + 3
parçaya tire ekleriz. Bu, tüm deliklerin altındaki en alttaki sıradır.
for
Parçanın gerçekte inşa edildiği döngüyü açıklamak için kullandığım 4x4 parçası şuna benziyor:
___________\n
| o o o o |\n
| o o o o |\n
| o o o o |\n
| o o o o |\n
-----------
System.out.print(c);
Ve sonunda, parçayı basıyoruz!