我的编程空间,编程开发者的网络收藏夹
学习永远不晚

C++怎么实现矩阵赋零

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

C++怎么实现矩阵赋零

这篇文章主要介绍“C++怎么实现矩阵赋零”,在日常操作中,相信很多人在C++怎么实现矩阵赋零问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C++怎么实现矩阵赋零”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!

[LeetCode] 73.Set Matrix Zeroes 矩阵赋零

Given a m x n matrix, if an element is 0, set its entire row and column to 0. Do it in place.

click to show follow up.

Follow up:

Did you use extra space?
A straight forward solution using O(mn) space is probably a bad idea.
A simple improvement uses O(m + n) space, but still not the best solution.
Could you devise a constant space solution?

据说这题是CareerCup上的原题,我还没有刷CareerCup,所以不知道啦,不过这题也不算难,虽然我也是看了网上的解法照着写的,但是下次遇到绝对想的起来。这道题中说的空间复杂度为O(mn)的解法自不用多说,直接新建一个和matrix等大小的矩阵,然后一行一行的扫,只要有0,就将新建的矩阵的对应行全赋0,行扫完再扫列,然后把更新完的矩阵赋给matrix即可,这个算法的空间复杂度太高。将其优化到O(m+n)的方法是,用一个长度为m的一维数组记录各行中是否有0,用一个长度为n的一维数组记录各列中是否有0,最后直接更新matrix数组即可。这道题的要求是用O(1)的空间,那么我们就不能新建数组,我们考虑就用原数组的第一行第一列来记录各行各列是否有0.

- 先扫描第一行第一列,如果有0,则将各自的flag设置为true
- 然后扫描除去第一行第一列的整个数组,如果有0,则将对应的第一行和第一列的数字赋0
- 再次遍历除去第一行第一列的整个数组,如果对应的第一行和第一列的数字有一个为0,则将当前值赋0
- 最后根据第一行第一列的flag来更新第一行第一列

代码如下:

class Solution {public:    void setZeroes(vector<vector<int> > &matrix) {        if (matrix.empty() || matrix[0].empty()) return;        int m = matrix.size(), n = matrix[0].size();        bool rowZero = false, colZero = false;        for (int i = 0; i < m; ++i) {            if (matrix[i][0] == 0) colZero = true;        }        for (int i = 0; i < n; ++i) {            if (matrix[0][i] == 0) rowZero = true;        }         for (int i = 1; i < m; ++i) {            for (int j = 1; j < n; ++j) {                if (matrix[i][j] == 0) {                    matrix[0][j] = 0;                    matrix[i][0] = 0;                }            }        }        for (int i = 1; i < m; ++i) {            for (int j = 1; j < n; ++j) {                if (matrix[0][j] == 0 || matrix[i][0] == 0) {                    matrix[i][j] = 0;                }            }        }        if (rowZero) {            for (int i = 0; i < n; ++i) matrix[0][i] = 0;        }        if (colZero) {            for (int i = 0; i < m; ++i) matrix[i][0] = 0;        }    }};

到此,关于“C++怎么实现矩阵赋零”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注编程网网站,小编会继续努力为大家带来更多实用的文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

C++怎么实现矩阵赋零

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

C++怎么实现矩阵赋零

这篇文章主要介绍“C++怎么实现矩阵赋零”,在日常操作中,相信很多人在C++怎么实现矩阵赋零问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”C++怎么实现矩阵赋零”的疑惑有所帮助!接下来,请跟着小编一起来学习吧
2023-06-20

C++稀疏矩阵怎么实现

这篇文章主要讲解了“C++稀疏矩阵怎么实现”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“C++稀疏矩阵怎么实现”吧!稀疏矩阵矩阵与稀疏矩阵的定义Q:什么是矩阵A:数学上,一个矩阵由 m 行
2023-06-30

C++怎么实现螺旋矩阵

本篇内容介绍了“C++怎么实现螺旋矩阵”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!螺旋矩阵Given a positive integer
2023-06-20

c#矩阵怎么写

在 c# 中创建矩阵的方法有:使用锯齿数组:创建一个数组的数组,每行元素数量可能不同。使用 jaggedarray 类:提供更简单的锯齿数组创建方法。使用 system.numerics.matrix 类:提供丰富的矩阵操作功能,例如转置和
c#矩阵怎么写
2024-05-12

numpy对矩阵元素怎么赋值

使用NumPy可以通过索引来赋值矩阵元素。具体的赋值操作取决于你想要赋值的矩阵的维度。对于一维数组,可以使用索引来赋值元素。例如:```pythonimport numpy as nparr = np.array([1, 2, 3, 4,
2023-08-19

mat矩阵和npy矩阵怎么实现互相转换

这篇“mat矩阵和npy矩阵怎么实现互相转换”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“mat矩阵和npy矩阵怎么实现互相
2023-07-02

python共现矩阵怎么实现

本篇内容主要讲解“python共现矩阵怎么实现”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“python共现矩阵怎么实现”吧!什么是共现矩阵比如我们有两句话:ls = [我永远喜欢三上悠亚, 三
2023-07-06

c++中eigen矩阵赋值的方法是什么

在Eigen中,可以通过括号初始化、逐个元素赋值、块赋值等方式对矩阵进行赋值。使用括号初始化:Eigen::MatrixXf mat(3, 3); // 创建一个3x3的矩阵mat << 1, 2, 3,4, 5, 6,7, 8, 9;
c++中eigen矩阵赋值的方法是什么
2024-03-12

matlab建立空矩阵后怎么赋值

在Matlab中,可以使用赋值语句将值分配给已经创建的空矩阵。下面是一些示例代码:1. 赋值给单个元素:```matlabA = []; % 创建一个空矩阵A(1,1) = 5; % 将值5分配给矩阵的第一个元素```2. 赋值给整
2023-09-21

python二维矩阵怎么实现

Python中可以使用列表(list)来表示二维矩阵。可以通过嵌套列表的方式来表示二维矩阵的行和列。以下是几种创建二维矩阵的方法:使用列表生成式:matrix = [[0 for _ in range(cols)] for _ in ra
2023-10-22

python旋转矩阵怎么实现

要实现矩阵的旋转,可以使用numpy库中的rot90函数。下面是一个简单的示例代码:import numpy as np# 创建一个2x3的矩阵matrix = np.array([[1, 2, 3],[4, 5, 6]])# 将矩阵逆
2023-10-21

C++利用伴随阵法实现矩阵求逆

这篇文章主要为大家详细介绍了C++如何利用伴随阵法实现矩阵求逆,文中的示例代码讲解详细,具有一定的学习和借鉴价值,需要的可以参考一下
2023-02-10

python怎么给矩阵指定元素赋值

在Python中,可以使用索引来给矩阵的指定元素赋值。下面是一种常用的方法:```pythonmatrix = [[1, 2, 3], [4, 5, 6], [7, 8, 9]] # 定义一个矩阵matrix[0][0] = 10 #
2023-08-19

C/C++实现蛇形矩阵的示例代码怎么写

这篇文章将为大家详细讲解有关C/C++实现蛇形矩阵的示例代码怎么写,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。菜鸡蒟蒻想在博客中记录一些算法学习的心得体会,会持续更新C/C++方面的题解,
2023-06-26

怎么使用Python实现生成对角矩阵和对角块矩阵

这篇文章主要介绍了怎么使用Python实现生成对角矩阵和对角块矩阵的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇怎么使用Python实现生成对角矩阵和对角块矩阵文章都会有所收获,下面我们一起来看看吧。对角矩阵s
2023-07-06

C语言如何实现杨氏矩阵

本篇内容主要讲解“C语言如何实现杨氏矩阵”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C语言如何实现杨氏矩阵”吧!题目如下:有一个数字矩阵,矩阵的每行从左到右是递增的,矩阵从上到下是递增的,请编
2023-07-05

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录