多维数组与矩阵之0所在的行列清零

问题描述

如果矩阵中的某个元素为0,则将其所在行和列清零
例如:
4 X 4矩阵
输出:
在这里插入图片描述

算法思路

这是一道考察数组下标的算法,有个小坑是:如果采用遇到一个零处理一个的方式,即在原数组上遇到一个零就把其对应的行和列元素变为零,则会把整个数组都变为0。

因为这是一个循环的过程,本来原数组中不为0的元素被消为0,产生错误,在数组中有0的情况下,整个数组都会被消为0。

所以采用新的数组来记录原数组中0元素的下标,用两个一维数组(分别长度为M、N)来替代一个M X N的二维数组,节省空间。

代码实现

public class _02_0所在的行列清零 {
    public static void main(String[] args) {
        int[][] matrix = {
                {1,2,0,4},
                {5,6,7,8},
                {9,0,11,12},
                {13,14,15,16}
        };
        solve(matrix);

    }
    public static void sol
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值