gpt4 book ai didi

java - 检查循环是否在没有条件中断的情况下运行

转载 作者:太空宇宙 更新时间:2023-11-04 14:05:21 24 4
gpt4 key购买 nike

我目前正在执行一项编程任务。在这个作业中,我得到了一个随机的 Ascii 图像。我的工作是将其转换为 CSV 格式。例如:ascii 图像:

3
**
******
** *+

csv 格式:

3
2, ,2,*,2,
6,*
2, ,2*,1, ,1,*,1,+

这是我的代码:

public static void imageToNumRep(File input, File output)
throws FileNotFoundException
{
Scanner in = new Scanner(input);
PrintStream out = new PrintStream(output);
while(in.hasNextLine())
{
int count = 0;
String text = in.nextLine();
for (int i = 0; i <= text.length() -2; i++)
{
if (text.charAt(i) == text.charAt(i + 1))
{
count++;
}
if (text.charAt(i) != text.charAt(i + 1))
{
System.out.print(count+1+ "," + text.charAt(i)+ ", ");
count = 0;
}
}
int count2 = 0;
for (int j = text.length()-1 ; j>0 ; j--)
{

if (text.charAt(j - 1) == text.charAt(j))
{
count2++;
}
if (text.charAt(j) != text.charAt(j - 1))
{
System.out.println(count2 + 1 + "," + text.charAt(j));
count2 = 0;
break;
}
}
}
}

我想做的是遍历图像中的每一行。在每一行中,我将从第一个字符到最后一个字符,或者反之亦然。如果当前字符与下一个字符相同,我将有一个计数器来计数。当我到达当前字符与下一个字符或前一个字符不同时,我将打印出计数和字符,指示我刚刚运行了多少个字符,然后重置计数。

问题是此代码仅适用于具有不同字符的行。当我浏览从头到尾具有相同字符的行时,我无法打印该行,因为我需要在该行中使用不同的字符才能打印。有什么想法吗?

最佳答案

循环的一般结构(伪代码)是这样的(我将使用 else,但它与示例代码的想法相同):

for every character in string {
if some condition is true {
...
} else {
output "the condition is false";
break;
}
}

您遇到的问题是,如果字符串中的每个字符都满足某些条件(例如所有字符都相同),您希望采取一些操作(例如打印字符串)。当然,只有在完成循环之后您才能知道这一点。典型的方法是找到某种方法使该信息在循环之外可用。例如考虑一下:

boolean atLeastOneFalse = false; // we'll use this flag...

for every character in string {
if some condition is true {
...
} else {
output "the condition is false";
atLeastOneFalse = true; // ...to track if our condition is false...
break;
}
}

if (!atLeastOneFalse) { // ... so we can tell if it was ever false or not when we're done checking.
output "the condition was always true!";
}

这里我们使用一个标志来跟踪循环外循环中发生的情况。如果循环中的每次迭代条件都为 true,则我们的标志将永远不会被触及,并且在循环后将保持 false。但如果条件为假,我们的标志就会被设置。

上面的方法非常干净且易于阅读。沿着相同思路的第二种方法(从循环中获取可用信息)是在循环外部声明索引计数器,然后在最后检查它的值。例如:

int n;

for (n = 0; n < final value; ++ n) {
if some condition is true {
...
} else {
output "the condition is false";
break;
}
}

if (n == final value) { // then we never broke out of the loop early, therefore the condition was never false
output "the condition was always true!";
}

当然有一些方法可以重新组织上述代码以最大程度地减少行数,但我想保持清晰,而不是一次引入太多内容。

这种方式的缺点是更容易出错。请注意,“最终值”使用了两次。这意味着,如果您通过修改“最终值”等方式修改代码,则需要更新两行而不是一行。这增加了意外忘记更新的可能性。当然,如果您将“最终值”存储在变量中,您可以消除这种情况,但我发现标志方法更简单。您总是希望构建代码以尽量减少出错的可能性。

还有第三种可能性,您有时可能会看到,即检查循环本身是否处于循环末尾(例如,if (n == Final value - 1) { we made it through; } 在循环内部但在 break 之后)。我不会给出例子,因为我不喜欢这种方法。从哲学上讲,它存在一些更深层次的组织问题,并且在某些情况下也可能存在性能问题。我会采用上面的标志方法。

希望这些信息足以让您了解如何解决应用程序中的问题。

关于java - 检查循环是否在没有条件中断的情况下运行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28921546/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com