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

嵌入式工程师

3次就业内推,全流程就业服务,行业风口、政策倾斜,新晋热门高薪不内卷,越老越吃香!0基础一站式就业完整路径,抢占先发优势!

【第1周】迈进供不应求的物联网/嵌入式行业大门
【第2周】C语言进阶-编程思想与高级进阶
【第3周】C语言项目实战与《阶段笔试》
【第4周】数据结构-线性/非线性结构、排序及综合实战
【第5周】Shell编程和Makefile工程管理
【第6周】Linux文件IO和标准IO
【第7周】Linux 多进程、多线程、IO模型
【第8周】网络基础和UDP Socket编程
【第9周】TCP Socket编程和WireShark抓包分析
【第10周】智能硬件开发-ARM核介绍和基础外设
【第11周】智能硬件开发-单片机常用外设
【第12周】stm32芯片-智能硬件项目实战
【第13周】Stm32 FreeRTOS实战
【第14周】大厂必备- linux内核与文件系统移植
【第15周】嵌入式开发-系统移植-bootloader、yocto
【第16周】嵌入式底层核心技能-Linux设备驱动初级
【第17周】嵌入式底层核心技能-Linux设备驱动中级
【第18周】嵌入式底层核心技能-Linux设备驱动高级
【第19周】从C到C++
【第20周】软件设计模式与C++11新特性
【第21周】趣味项目实战-C++语言实现五子棋游戏
【第22周】嵌入式产品人机交互必备-QT框架
【第23周】项目实战-QT开发音乐播放器
【第24周】智能家居项目实战之Linux智能网关端开发
【第25周】智能家居项目实战之STM32单片机设备端开发
【第26周】嵌入式底层核心高阶技能-Linux设备驱动高级进阶
【第27周】人脸指纹识别考勤机设计与实战
【第28周】就业项目、简历优化、名企内推等1v1指导
章节
问答
课签
笔记
评论
占位
占位

强者争霸

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

任务

?不会了怎么办
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个积分

继续发表请点击 "确定"

为什么扣积分?