当前位置: 首页 > article >正文

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

 

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

 

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


http://www.kler.cn/a/599823.html

相关文章:

  • vulkanscenegraph显示倾斜模型(5.4)-相机操纵器
  • 如何查看Unity打包生成的ab文件
  • 23种设计模式-桥接(Bridge)设计模式
  • FPGA_DDS_IP核
  • CS实现票据样式效果
  • 国科云:浅谈DNS在IPv6改造过程中的重要性
  • OpenHarmony子系统开发 - 电池管理(二)
  • Docker-初级安装及使用
  • UE5.5 Niagara 渲染器
  • 渐进式Web应用(PWA)基础教程
  • 回溯-单词搜索
  • 《mysql篇》--JDBC编程
  • ios分析app卡顿问题方案
  • 以太坊兼容智能合约即将登陆 Kusama!Polkadot 迎来智能合约新时代
  • Java高频面试之集合-17
  • 【C/C++】在排序数组中查找元素的第一个和最后一个位置(leetcode T34)
  • Flutter项目升级到指定版本的详细步骤指南
  • 重要重要!!fisher矩阵是怎么计算和更新的,以及计算过程中参数的物理含义
  • 如何让WordPress不同的页面、栏目显示不同的小工具侧边栏
  • 新版frp-0.61.0 实现泛解析域名穿透 以及 https启用