在解决LeetCode等编程平台上的算法问题时,正确处理输入数据是解题的第一步。本文以Java语言为例,详细讲解如何正确读取由0和1组成的二维字符矩阵,并解决输入过程中可能遇到的换行符问题。
---
#### **问题背景**
题目要求从输入中读取一个二维字符矩阵,例如:
```plaintext
4 5
10100
10111
11111
10010
```
其中第一行表示矩阵的行数(`m=4`)和列数(`n=5`),后续每一行为矩阵的具体内容。
---
#### **输入处理的核心代码**
```java
Scanner sc = new Scanner(System.in);
int m = sc.nextInt();
int n = sc.nextInt();
sc.nextLine(); // 关键:跳过换行符
char[][] matrix = new char[m][n];
for (int i = 0; i < m; i++) {
String line = sc.nextLine();
for (int j = 0; j < n; j++) {
matrix[i][j] = line.charAt(j);
}
}
```
---
#### **关键知识点解析**
1. **读取行列数后的换行符处理**
使用`sc.nextInt()`读取`m`和`n`时,输入流中会残留换行符(用户输入`4 5`后按下的回车)。
此时必须调用`sc.nextLine()`**显式跳过这个换行符**,否则后续读取的`line`可能为空字符串,导致逻辑错误。
2. **按行读取字符串并填充矩阵**
通过`sc.nextLine()`逐行读取字符串,例如`10100`表示第一行的字符。
使用`line.charAt(j)`逐个字符填充到二维数组`matrix[i][j]`中。
---
#### **常见错误及解决方案**
- **错误1:未处理换行符**
若省略`sc.nextLine()`,首次调用`sc.nextLine()`会读取到空字符串,导致矩阵填充错位。
**解决方案**:在读取`m`和`n`后,立即调用`sc.nextLine()`。
- **错误2:输入行长度不足或超长**
若某行字符串长度不等于`n`,例如输入`101`但`n=5`,会抛出`StringIndexOutOfBoundsException`。
**解决方案**:假设题目保证输入合法,实际开发中需增加长度校验。
---
#### **完整输入流程示例**
假设输入为:
```plaintext
4 5
10100
10111
11111
10010
```
- `m=4`,`n=5`,通过`sc.nextLine()`跳过换行符。
- 循环读取4行字符串,并逐个字符填充到`matrix`中。
---
#### **总结**
正确处理输入的核心在于:
1. **显式跳过换行符**:在读取行列数后,使用`sc.nextLine()`清除输入流中的换行符。
2. **按行填充字符**:逐行读取字符串,并通过`charAt()`方法填充二维数组。
通过这种方式,可以高效、准确地构建题目所需的二维字符矩阵,为后续算法逻辑的实现奠定基础。