课程设计|C++C++程序设计基础:矩阵运算器

Posted 海轰Pro

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了课程设计|C++C++程序设计基础:矩阵运算器相关的知识,希望对你有一定的参考价值。

前言

Hello!小伙伴!
非常感谢您阅读海轰的文章,倘若文中有错误的地方,欢迎您指出~
 
自我介绍 ଘ(੭ˊᵕˋ)੭
昵称:海轰
标签:程序猿|C++选手|学生
简介:因C语言结识编程,随后转入计算机专业,有幸拿过国奖、省奖等,已保研。目前正在学习C++/Linux(真的真的太难了~)
学习经验:扎实基础 + 多做笔记 + 多敲代码 + 多思考 + 学好英语!

课程设计要求

  • 设计一个程序实现两个矩阵的基本运算
  • 两个矩阵相加
  • 两个矩阵相减
  • 两个矩阵相乘
  • 求一个矩阵的转置矩阵

难度 🌟

运行界面

运行环境:Visual Studio Code

1.矩阵a、b初始化

// 矩阵a,b
vector<vector<int> > a;
vector<vector<int> > b;

// 输入矩阵
vector<vector<int> > input(string name)
{
  vector<vector<int> > ans;
  int m = 0;
  int n = 0;
  cout << "请输入矩阵" << name << "的行、列数(以空格间隔 例如: 2 2):";
  cin >> m >> n;
  for (int i = 0; i < m; ++i)
  {
    cout << "请输入第" << (i + 1) << "行元素(各元素之间以空格隔开)" << endl;
    vector<int> temp;
    for (int j = 0; j < n; ++j)
    {
      int num;
      cin >> num;
      temp.push_back(num);
    }
    ans.push_back(temp);
  }
  return ans;
}

// 初始化 矩阵a b
void initial()
{
  a.clear();
  b.clear();
  a = input("a");
  b = input("b");
}

效果图如下
在这里插入图片描述
2.菜单显示

// 菜单显示
void menu()
{
  cout << "**************************" << endl;
  cout << "           菜单            " << endl;
  cout << "      1. 矩阵加法           " << endl;
  cout << "      2. 矩阵减法           " << endl;
  cout << "      3. 矩阵乘法           " << endl;
  cout << "      4. 矩阵转置           " << endl;
  cout << "      5. 清空矩阵           " << endl;
  cout << "      6. 退出程序           " << endl;
  cout << "**************************" << endl;
  cout << "请输入您的选择:【例如选择1.矩阵加法 请输入:1】" << endl;
}

效果图如下

在这里插入图片描述
3.矩阵加法

// add() : 矩阵加法
void add()
{
  // 判断是否可以相加
  if (a.size() == b.size() && a.back().size() == b.back().size())
  {
    vector<vector<int> > sum(a.size(), vector<int>(a[0].size(), 0));
    for (int i = 0; i < a.size(); ++i)
    {
      for (int j = 0; j < a[0].size(); ++j)
      {
        sum[i][j] = a[i][j] + b[i][j];
      }
    }
    cout << "矩阵a,b 相加的结果如下:" << endl;
    for (int i = 0; i < sum.size(); ++i)
    {
      for (int j = 0; j < sum[0].size(); ++j)
      {
        cout << sum[i][j] << " ";
      }
      cout << endl;
    }
  }
  else
  {
    cout << "矩阵a,b 不可以进行相加!" << endl;
  }
}

效果图如下

在这里插入图片描述
4.矩阵减法

// sub() 矩阵减法
void sub()
{
  // 判断是否可以相减
  if (a.size() == b.size() && a.back().size() == b.back().size())
  {
    vector<vector<int> > sum(a.size(), vector<int>(a[0].size(), 0));
    for (int i = 0; i < a.size(); ++i)
    {
      for (int j = 0; j < a[0].size(); ++j)
      {
        sum[i][j] = a[i][j] - b[i][j];
      }
    }
    cout << "矩阵a,b 相减的结果如下:" << endl;
    for (int i = 0; i < sum.size(); ++i)
    {
      for (int j = 0; j < sum[0].size(); ++j)
      {
        cout << sum[i][j] << " ";
      }
      cout << endl;
    }
  }
  else
  {
    cout << "矩阵a,b 不可以进行相减!" << endl;
  }
}

效果图如下

在这里插入图片描述
5.矩阵乘法

// mul() 矩阵乘法
void mul()
{
  // 判断是否可以相乘 (m✖️n)* (n✖️k)
  if (a[0].size() == b.size())
  {
    vector<vector<int> > res(a.size(), vector<int>(b[0].size(), 0));
    for (int i = 0; i < a.size(); ++i)
    {
      for (int j = 0; j < b[0].size(); ++j)
      {
        int sum = 0;
        for (int k = 0; k < b.size(); ++k)
        {
          sum += (a[i][k] * b[k][j]);
        }
        res[i][j] = sum;
      }
    }
    cout << "矩阵a,b 相乘的结果如下:" << endl;
    for (int i = 0; i < res.size(); ++i)
    {
      for (int j = 0; j < res[0].size(); ++j)
      {
        cout << res[i][j] << " ";
      }
      cout << endl;
    }
  }
  else
  {
    cout << "矩阵a,b不可以进行相乘!" << endl;
  }
}

效果图如下

在这里插入图片描述
6.矩阵转置

// 转置
void transpose()
{
  cout << "转置矩阵 选择:1.a矩阵 2.b矩阵 " << endl;
  cout << "请输入你的选择:";
  int choice;
  cin >> choice;
  vector<vector<int> > temp;
  switch (choice)
  {
  case 1:
    temp = a;
    break;
  case 2:
    temp = b;
    break;
  default:
    cout << "输入错误!" << endl;
    break;
  }
  vector<vector<int> > res(temp[0].size(), vector<int>(temp.size(), 0));
  for (int i = 0; i < temp.size(); ++i)
  {
    for (int j = 0; j < temp[0].size(); ++j)
    {
      res[j][i] = temp[i][j];
    }
  }
  cout << "矩阵转置的结果如下:" << endl;
  for (int i = 0; i < res.size(); ++i)
  {
    for (int j = 0; j < res[0].size(); ++j)
    {
      cout << res[i][j] << " ";
    }
    cout << endl;
  }
}

效果图如下

在这里插入图片描述
7.重置矩阵

// 清空矩阵a b
void clear()
{
  a.clear();
  b.clear();
  cout << "清空矩阵成功!" << endl;
}

效果图如下

在这里插入图片描述

源码

/*
 write by Haihong
 2021 07 06
 首发于:工种号【海轰Pro】
*/

#include <iostream>
#include <vector>
using namespace std;

// 矩阵a,b
vector<vector<int> > a;
vector<vector<int> > b;

// 输入矩阵
vector<vector<int> > input(string name)
{
  vector<vector<int> > ans;
  int m = 0;
  int n = 0;
  cout << "请输入矩阵" << name << "的行、列数(以空格间隔 例如: 2 2):";
  cin >> m >> n;
  for (int i = 0; i < m; ++i)
  {
    cout << "请输入第" << (i + 1) << "行元素(各元素之间以空格隔开)" << endl;
    vector<int> temp;
    for (int j = 0; j < n; ++j)
    {
      int num;
      cin >> num;
      temp.push_back(num);
    }
    ans.push_back(temp);
  }
  return ans;
}

// 初始化 矩阵a b
void initial()
{
  a.clear();
  b.clear();
  a = input("a");
  b = input("b");
}

// add() : 矩阵加法
void add()
{
  // 判断是否可以相加
  if (a.size() == b.size() && a.back().size() == b.back().size())
  {
    vector<vector<int> > sum(a.size(), vector<int>(a[0].size(), 0));
    for (int i = 0; i < a.size(); ++i)
    {
      for (int j = 0; j < a[0].size(); ++j)
      {
        sum[i][j] = a[i][j] + b[i][j];
      }
    }
    cout << "矩阵a,b 相加的结果如下:" << endl;
    for (int i = 0; i < sum.size(); ++i)
    {
      for (int j = 0; j < sum[0].size(); ++j)
      {
        cout << sum[i][j] << " ";
      }
      cout << endl;
    }
  }
  else
  {
    cout << "矩阵a,b 不可以进行相加!" << endl;
  }
}

// sub() 矩阵减法
void sub()
{
  // 判断是否可以相减
  if (a.size() == b.size() && a.back().size() == b.back().size())
  {
    vector<vector<int> > sum(a.size(), vector<int>(a[0].size(), 0));
    for (int i = 0; i < a.size(); ++i)
    {
      for (int j = 0; j < a[0].size(); ++j)
      {
        sum[i][j] = a[i][j] - b[i][j];
      }
    }
    cout << "矩阵a,b 相减的结果如下:" << endl;
    for (int i = 0; i < sum.size(); ++i)
    {
      for (int j = 0; j < sum[0].size(); ++j)
      {
        cout << sum[i][j] << " ";
      }
      cout << endl;
    }
  }
  else
  {
    cout << "矩阵a,b 不可以进行相减!" << endl;
  }
}

// mul() 矩阵乘法
void mul()
{
  // 判断是否可以相乘 (m✖️n)* (n✖️k)
  if (a[0].size() == b.size())
  {
    vector<vector<int> > C语言课程设计——25道蓝桥杯练习题

c语言学生成绩管理系统课程设计

MATLAB课程设计心得

求问!!!数据结构课程设计题:病毒测试程序。(c语言)

c语言设计一个简单的计算器程序

课程设计必备之数据库操作代码模板