thu*_*zle 6 java algorithm ascii function
我试着打印这样的东西:
+--------+
| /\ |
| /--\ |
| /====\ |
|<------>|
| \====/ |
| \--/ |
| \/ |
+--------+
Run Code Online (Sandbox Code Playgroud)
到目前为止,我已经成功地打印了图中的第一部分但是第二部分很难.
这是我打印图的第一部分的方式:
for (int fill = 0; fill <= ((2 * row - 1)); fill++) {
if ((row % 2) == 0) {
System.out.print("=");
} else {
System.out.print("-");
}
}
Run Code Online (Sandbox Code Playgroud)
我的第二部分是
for (int fill = 0; fill <= (n - 2 * (row - 1)); fill++) { //This is where I need help
if ((row % 2) == 0) {
System.out.print("=");
} else {
System.out.print("-");
}
}
Run Code Online (Sandbox Code Playgroud)
我的结果如下:
+--------+
| /\ |
| /--\ |
| /====\ |
|<------>|
| \=====/ |
| \---/ |
| \=/ |
+--------+
Run Code Online (Sandbox Code Playgroud)
有关完整代码,请查看:http://pastebin.com/YyCJ6Cq3
正如您所看到的,您在钻石内打印了太多的列。因此解决方法应该很简单 - 每次少打印一列,这是通过将循环运行的次数减少一次来实现的。一般来说,您可以- 1
像 @samgak 建议的那样在条件末尾添加 a ,但这实际上在这里不起作用。让我们尝试了解您为何会遇到此问题。
你的第一个循环不依赖于n
; 它仅使用当前行索引来确定要打印的字符数。
在第二个循环中,您正确地还需要包含n
以便从大值开始并减少 的值fill
,但您滥用了它。n
和row
的量级相同(因为row
是根据 定义的n
),但只需row
乘以2
。相反,您应该先执行该n-row
操作,然后按比例缩放结果,2
以便在每行中打印 2x 个字符。2*(n-row)
由于不太正确,您将不得不进一步尝试它,但希望这足以帮助您解决问题。