### Java二维字符矩阵输入解析:正确读取由0和1组成的矩阵

在解决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`可能为空字符串,导致逻辑错误。

  1. **按行读取字符串并填充矩阵**

通过`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()`方法填充二维数组。

通过这种方式,可以高效、准确地构建题目所需的二维字符矩阵,为后续算法逻辑的实现奠定基础。

相关推荐
Miraitowa_cheems23 分钟前
LeetCode算法日记 - Day 64: 岛屿的最大面积、被围绕的区域
java·算法·leetcode·决策树·职场和发展·深度优先·推荐算法
Christo332 分钟前
关于K-means和FCM的凸性问题讨论
人工智能·算法·机器学习·数据挖掘·kmeans
Lisonseekpan44 分钟前
Spring Boot 中使用 Caffeine 缓存详解与案例
java·spring boot·后端·spring·缓存
为java加瓦1 小时前
Rust 的类型自动解引用:隐藏在人体工学设计中的魔法
java·服务器·rust
SimonKing1 小时前
分布式日志排查太头疼?TLog 让你一眼看穿请求链路!
java·后端·程序员
消失的旧时光-19431 小时前
Kotlin 判空写法对比与最佳实践
android·java·kotlin
_不会dp不改名_1 小时前
leetcode_1382 将二叉搜索树变平衡树
算法·leetcode·职场和发展
小许学java1 小时前
Spring AI快速入门以及项目的创建
java·开发语言·人工智能·后端·spring·ai编程·spring ai
一叶飘零_sweeeet1 小时前
从 “死锁“ 到 “解耦“:重构中间服务破解 Java 循环依赖难题
java·循环依赖
greentea_20132 小时前
Codeforces Round 173 B. Digits(2043)
c++·算法