解锁即可观看《物联网/嵌入式工程师》完整课程视频

物联网/嵌入式工程师

面向零基础保姆式教学+简历指导+1V1模拟面试+3次内推,助力轻松就业!

【第0周】物联网/嵌入式工程师就业班开学典礼
【第1周】嵌入式开发基石-计算机基础与C语言
【第2周】C语言进阶-编程思想
【第3周】C语言高级进阶
【第4周】C语言项目实战与《阶段笔试》
【第5周】数据结构-线性结构
【第6周】数据结构-非线性结构
【第7周】排序与复杂度
【第8周】数据结构项目实战
【第9周】Shell编程和Makefile工程管理
【第10周】Linux文件IO和标准IO
【第11周】Linux下文件操作项目实践与阶段评测
【第12周】Linux 多进程、多线程、IO模型
【第13周】Linux 项目实战-实现并发服务器模型与企业笔试
【第14周】网络基础和UDP Socket编程
【第15周】TCP Socket编程和WireShark抓包分析
【第16周】网络编程项目实战-网络视频监控与企业笔试
【第17周】从C到C++
【第18周】软件设计模式与C++11新特性
【第19周】项目实战-C++语言实现五子棋游戏与企业笔试
【第20周】嵌入式产品人机交互必备-QT框架
【第21周】项目实战-QT开发音乐播放器
【第22周】智能硬件开发-ARM核介绍和基础外设
【第23周】智能硬件开发-单片机常用外设
【第24周】stm32芯片-智能硬件项目实战与企业笔试
【第25周】大厂必备- linux内核与文件系统移植
【第26周】嵌入式开发-系统移植-bootloader、yocto
【第27周】嵌入式底层核心技能-Linux设备驱动初级
【第28周】嵌入式底层核心技能-Linux设备驱动中级
【第29周】嵌入式底层核心技能-Linux设备驱动高级1
【第30周】嵌入式底层核心技能-Linux设备驱动高级2
【第31周】智能家居项目实战之Linux智能网关端开发
【第32周】智能家居项目实战之STM32单片机设备端开发
【第33周】智能家居项目实战之Qt用户APP端开发
【第34周】嵌入式人工智能必备-Python
【第35周】物联网/嵌入式项目答辩和就业指导
【第36周】独立开发阶段-三大热门领域项目
章节
问答
课签
笔记
评论
占位
占位

强者争霸

矩阵是我们常用的数学工具,请你编写一个矩阵的工具类,要求包含矩阵的乘法功能,当然,拷贝也是必要的

任务

?不会了怎么办
class Mat

{
public:
    int row = 0;
    int col = 0;
    float * * mat = nullptr;

private:
    void init(int row, int col)
    {
        if (row && col) {
            mat = new float*[row];
            for (int i = 0; i < row; i++) {
                mat[i] = new float[col];
                for (int j = 0; j < col; j++){
                    mat[i][j] = 0;
                    if(i == j){
                        mat[i][j] = 1;
                    }
                }
            }
        }
    }

public:
    Mat(int row = 0, int col = 0)
    {
        this->row = row;
        this->col = col;

        init(row, col);
    }

    Mat(const Mat &m)
    {
        this->row = m.row;
        this->col = m.col;

        init(row, col);
        for (int i = 0; i < row; i++){
            for (int j = 0; j < col; j++){
                mat[i][j] = m.mat[i][j];
            }
        }
    }

    ~Mat()
    {
        if (mat != nullptr) {
            for (int i = 0; i < row; i++){
                if (mat[i]) {
                    delete[] mat[i];
                    mat[i] = nullptr;
                }
            }
            if (mat){
                delete[] mat;
            }   
            mat = nullptr;
        }
    }

    Mat & operator = (const Mat &m)
    {
        if (mat != nullptr) {
            for (int i = 0; i < row; i++){
                if (mat[i]) {
                    delete[] mat[i];
                    mat[i] = nullptr;
                }
            }
            if (mat){
                delete[] mat;
            }
            mat = nullptr;
        }

        row = m.row;
        col = m.col;

        init(row, col);
        for (int i = 0; i < row; i++){
            for (int j = 0; j < col; j++){
                mat[i][j] = m.mat[i][j];
            }
        }

        return *this;
    }

    Mat operator * (const Mat &m)
    {
        EyerMat res(row, m.col);
        
        for (int i = 0; i < res.row; i++) {
            for (int j = 0; j < res.col; j++) {
                res.mat[i][j] = 0.0f;
            }
        }

        if (m.row != col){

        }
        else {
            for (int i = 0; i < res.row; i++) {
                for (int j = 0; j < res.col; j++) {
                    for (int k = 0; k < res.row; k++) {
                        res.mat[i][j] += mat[i][k] * m.mat[k][j];
                    }
                }
            }
        }
            
        return res;
    }
}
||

提问题

写笔记

公开笔记
提交
||

请验证,完成请求

由于请求次数过多,请先验证,完成再次请求

加群二维码

打开微信扫码自动绑定

您还未绑定服务号

绑定后可得到

  • · 粉丝专属优惠福利
  • · 大咖直播交流干货
  • · 课程更新,问题答复提醒
  • · 账号支付安全提醒

收藏课程后,能更快找到我哦~

使用 Ctrl+D 可将课程添加到书签

邀请您关注公众号
关注后,及时获悉本课程动态

举报

0/150
提交
取消
全部 精华 我要发布
全部 我要发布
最热 最新
只看我的

手记推荐

更多

本次提问将花费2个积分

你的积分不足,无法发表

为什么扣积分?

本次提问将花费2个积分

继续发表请点击 "确定"

为什么扣积分?