news 2026/4/16 19:33:20

华为OD机试 B卷 - 稀疏矩阵扫描 (C++ Python JAVA JS GO)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
华为OD机试 B卷 - 稀疏矩阵扫描 (C++ Python JAVA JS GO)

稀疏矩阵扫描

华为OD机试B卷 - 华为OD上机考试B卷 100分题型

华为OD机试真题目录点击查看: 华为OD机试真题题库目录|机考题库 + 算法考点详解

题目描述

如果矩阵中的许多系数都为零,那么该矩阵就是稀疏的。对稀疏现象有兴趣是因为它的开发可以带来巨大的计算节省,并且在许多大的实践中都会出现矩阵稀疏的问题。

给定一个矩阵,现在需要逐行和逐列地扫描矩阵,如果某一行或者某一列内,存在连续出现的0的个数超过了行宽或者列宽的一半 [W /2] (整除) ,则认为该行或者该列是稀疏的。

扫描给定的矩阵,输出稀疏的行数和列数。

输入描述

第一行输入为M和N,表示矩阵的大小M*N,0 < M ≤ 100,0 < N ≤ 100

接下来M行输入为矩阵的成员,每行N个成员,矩阵成员都是有符号整数,范围-32,768到32,767

输出描述

输出两行,第一行表示稀疏行的个数,第二行表示稀疏列的个数

用例1

输入

3 3 1 0 0 0 1 0 0 0 1

输出

3 3

说明

给定的3*3矩阵里,每一行和每一列内都存在2个0,行宽3,列宽3,[3/2] = 1,因此稀疏行有3个,稀疏列有3个。

用例2

输入

5 3 -1 0 1 0 0 0 -1 0 0 0 -1 0 0 0 0

输出

5 3

说明

给定的5*3矩阵,每行里面0的个数大于等于1表示稀疏行,每列里面0的个数大于等于2表示稀疏行,所以有5个稀疏行,3个稀疏列。

题解

思路:模拟

  1. 首先这个题目有点问题,结合题目和用例来看,判断稀疏的情况是行中0的个数大于等于行宽一半, 列中0的个数大于等于列宽一般就认为稀疏
  2. 理明白1的规则之后,这道题就非常简单了,
  3. 统计每行/列中0的次数,然后按照1的规则进行判断统计
  4. 输出结果就行

c++

#include<iostream> #include<vector> #include<string> #include <utility> #include <sstream> #include<algorithm> #include<cmath> #include<map> using namespace std; int main() { int m , n; cin >> m >> n; vector<vector<int>> grid(m, vector<int>(n)); // 行0的个数 vector<int> zeroRowNum(m, 0); // 列0的个数 vector<int> zeroColNum(n, 0); for (int i = 0; i < m; i++) { for (int j = 0; j < n; j++) { cin >> grid[i][j]; if (grid[i][j] == 0) { zeroRowNum[i]++; zeroColNum[j]++; } } } // 计算满足条件的行和列 int rowResCount = 0, colResCount = 0; for (int i = 0; i < m; i++) { if (zeroRowNum[i] >= n / 2){ rowResCount++; } } for (int i = 0; i < n; i++) { if (zeroColNum[i] >= m / 2){ colResCount++; } } cout << rowResCount << endl; cout << colResCount << endl; }

JAVA

import java.util.Scanner; public class Main { public static void main(String[] args) { Scanner sc = new Scanner(System.in); int m = sc.nextInt(); int n = sc.nextInt(); int[][] grid = new int[m][n]; // 行0的个数 int[] zeroRowNum = new int[m]; // 列0的个数 int[] zeroColNum = new int[n]; for (int i = 0; i < m; i++) { for (int j = 0; j < n; j++) { grid[i][j] = sc.nextInt(); if (grid[i][j] == 0) { zeroRowNum[i]++; zeroColNum[j]++; } } } // 计算满足条件的行和列 int rowResCount = 0, colResCount = 0; for (int i = 0; i < m; i++) { if (zeroRowNum[i] >= n / 2) { rowResCount++; } } for (int i = 0; i < n; i++) { if (zeroColNum[i] >= m / 2) { colResCount++; } } System.out.println(rowResCount); System.out.println(colResCount); } }

Python

m,n=map(int,input().split())grid=[]zeroRowNum=[0]*m# 行0的个数zeroColNum=[0]*n# 列0的个数foriinrange(m):row=list(map(int,input().split()))grid.append(row)forjinrange(n):ifrow[j]==0:zeroRowNum[i]+=1zeroColNum[j]+=1# 计算满足条件的行和列rowResCount=sum(1forxinzeroRowNumifx>=n//2)colResCount=sum(1forxinzeroColNumifx>=m//2)print(rowResCount)print(colResCount)

JavaScript

constreadline=require('readline');constrl=readline.createInterface({input:process.stdin,output:process.stdout,terminal:false});letlines=[];rl.on('line',(line)=>{lines.push(line.trim());});rl.on('close',()=>{let[m,n]=lines[0].split(' ').map(Number);letgrid=Array.from({length:m},()=>Array(n).fill(0));letzeroRowNum=Array(m).fill(0);// 行0的个数letzeroColNum=Array(n).fill(0);// 列0的个数for(leti=0;i<m;i++){letrow=lines[i+1].split(' ').map(Number);for(letj=0;j<n;j++){grid[i][j]=row[j];if(row[j]===0){zeroRowNum[i]++;zeroColNum[j]++;}}}// 计算满足条件的行和列letrowResCount=zeroRowNum.filter(x=>x>=Math.floor(n/2)).length;letcolResCount=zeroColNum.filter(x=>x>=Math.floor(m/2)).length;console.log(rowResCount);console.log(colResCount);});

Go

packagemainimport("fmt")funcmain(){varm,nintfmt.Scan(&m,&n)grid:=make([][]int,m)zeroRowNum:=make([]int,m)// 行0的个数zeroColNum:=make([]int,n)// 列0的个数fori:=0;i<m;i++{grid[i]=make([]int,n)forj:=0;j<n;j++{fmt.Scan(&grid[i][j])ifgrid[i][j]==0{zeroRowNum[i]++zeroColNum[j]++}}}// 计算满足条件的行和列rowResCount,colResCount:=0,0fori:=0;i<m;i++{ifzeroRowNum[i]>=n/2{rowResCount++}}fori:=0;i<n;i++{ifzeroColNum[i]>=m/2{colResCount++}}fmt.Println(rowResCount)fmt.Println(colResCount)}
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/15 23:48:02

Go Module构建

添加依赖包 在Go Module项目中添加新依赖包&#xff0c;可以通过修改源码并执行相关命令完成。以添加github.com/google/uuid为例&#xff1a; package mainimport ("github.com/google/uuid""github.com/sirupsen/logrus" )func main() {logrus.Println(&…

作者头像 李华
网站建设 2026/4/15 17:01:21

Python类入门:用“汽车工厂”理解面向对象编程

引言&#xff1a;为什么需要“类”&#xff1f; 想象你是一家汽车工厂的工程师&#xff0c;每天要生产不同型号的汽车。如果每生产一辆车都要重新设计图纸、组装零件&#xff0c;效率会非常低。聪明的做法是&#xff1a;先设计一个“汽车模板”&#xff08;类&#xff09;&…

作者头像 李华
网站建设 2026/4/16 12:16:28

基于遗传(GA)、粒子群(PSO)、模拟退火(SA)、禁忌搜索(ST)、蚁群算法(ACO)、自自组织神经网络(SOM)的TSP算法研究附Python代码

✅作者简介&#xff1a;热爱科研的Matlab仿真开发者&#xff0c;擅长数据处理、建模仿真、程序设计、完整代码获取、论文复现及科研仿真。&#x1f34e; 往期回顾关注个人主页&#xff1a;Matlab科研工作室&#x1f34a;个人信条&#xff1a;格物致知,完整Matlab代码及仿真咨询…

作者头像 李华
网站建设 2026/4/16 10:39:01

DeepSeek-R1 与 OpenAI o3 的启示:Test-Time Compute 技术不再迷信参数堆叠

过去2年&#xff0c;整个行业仿佛陷入了一场参数竞赛&#xff0c;每一次模型发布的叙事如出一辙&#xff1a;“我们堆了更多 GPU&#xff0c;用了更多数据&#xff0c;现在的模型是 1750 亿参数&#xff0c;而不是之前的 1000 亿。” 这种惯性思维让人误以为智能只能在训练阶段…

作者头像 李华