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

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

相关推荐
崎岖Qiu22 分钟前
【设计模式笔记06】:单一职责原则
java·笔记·设计模式·单一职责原则
Hello.Reader28 分钟前
Flink ExecutionConfig 实战并行度、序列化、对象重用与全局参数
java·大数据·flink
前端炒粉1 小时前
18.矩阵置零(原地算法)
javascript·线性代数·算法·矩阵
熊小猿1 小时前
在 Spring Boot 项目中使用分页插件的两种常见方式
java·spring boot·后端
paopaokaka_luck1 小时前
基于SpringBoot+Vue的助农扶贫平台(AI问答、WebSocket实时聊天、快递物流API、协同过滤算法、Echarts图形化分析、分享链接到微博)
java·vue.js·spring boot·后端·websocket·spring
老华带你飞2 小时前
机器人信息|基于Springboot的机器人门户展示系统设计与实现(源码+数据库+文档)
java·数据库·spring boot·机器人·论文·毕设·机器人门户展示系统
AI Chen2 小时前
【矩阵分析与应用】【第1章 矩阵与线性方程组】【1.6.2.2 迹的循环置换性质】
矩阵·
notion20252 小时前
Adobe Lightroom Classic下载与安装教程(附安装包) 2025最新版详细图文安装教程
java·数据库·其他·adobe
暴风鱼划水2 小时前
三维重建【0-D】3D Gaussian Splatting:相机标定原理与步骤
算法·3d