首页 > 其他分享 >实验4 类与数组、指针

实验4 类与数组、指针

时间:2022-11-06 19:27:01浏览次数:43  
标签:const Matrix int double m1 数组 vectorInt 实验 指针

实验5:
#include<iostream>
using std::cout;
using std::endl;
using std::cin;

class vectorInt {
public:
    vectorInt(int n);
    vectorInt(int n, int m);
    ~vectorInt() { cout << "destructor called" << endl; delete[] p; }
    vectorInt(const vectorInt& p);
    int &at(int index);  
    int get_size()const;
    friend void output(vectorInt& p1);
private:
    int size;
    static int number ;//number用于记录调用构造函数的次数
    int* p;
};
vectorInt::vectorInt(int n) :size{n} {
    cout << "constructor " << number << " called" << endl; 
    p = new int[n];
    number = number + 1;
}
vectorInt::vectorInt(int n, int m) :size{n} {
    cout << "constructor " << number << " called" << endl;
    p = new int[n];
    for (int i = 0; i < n; i++)
        p[i] = m;
    number = number + 1;
}
vectorInt::vectorInt(const vectorInt& vp) :size{vp.size} {
    cout << "copy constructor called"<<endl;
    p = new int[size];
    for (auto i = 0; i < size; i++)
        p[i] = vp.p[i];
}
int &vectorInt::at(int index) {
    if (index >= 0 && index < size)
        return p[index];
}
int vectorInt::get_size()const {
    return size;
}

void output(vectorInt &p1) {
    for (int i = 0; i < p1.size; i++)
        cout << p1.p[i]<<", ";
    cout << endl;
}
int vectorInt::number = 1;

测试代码:

#include <iostream>
#include "vectorInt.hpp"

void test() {
    using namespace std;

    int n;
    cin >> n;

    vectorInt x1(n);
    for (auto i = 0; i < n; ++i)
        x1.at(i) = i * i;

    output(x1);

    vectorInt x2(n, 42);
    vectorInt x3(x2);

    output(x2);
    output(x3);

    x2.at(0) = 77;

    output(x2);
    output(x3);
}

int main() {
    test();
}

实验6:

#include<iostream>
using std::cout;
using std::endl;
class Matrix {
public:
	Matrix(int n);
	Matrix(int n, int m);
	Matrix(const Matrix& x);
	~Matrix();
	void set(const double* pvalue);
	void set(int i, int j, int value);
	double& at(int i, int j);
	double at(int i, int j)const;
	int get_lines()const;
	int get_cols()const;
	void print()const;
private:
	int lines;
	int cols;
	double* p;
};

Matrix::Matrix(int n) :lines{ n }, cols{n} {
	p = new double[n*n];
}
Matrix::Matrix(int n, int m) :lines{ n }, cols{m} {
	p = new double[n * m];
}
Matrix::Matrix(const Matrix& x) :lines{ x.lines }, cols{x.cols} {
	p = new double[lines * cols];
	for (int i = 0; i < lines; i++)
	{
		for(int j=0;j<cols;j++)
			p[i*cols+j]=x.p[i * cols + j];
	}
}
Matrix::~Matrix() { delete[]p; }

void Matrix::set(const double* pvalue) {
	for (int i = 0; i < lines * cols; i++)
		p[i] = pvalue[i];
}
void Matrix::set(int i, int j, int value) {
	p[i * cols + j] = value;
}
double& Matrix::at(int i, int j) {
		return p[i * cols + j ];
}
double Matrix::at(int i, int j)const { 
	  return p[i* cols + j]; 
}
int Matrix::get_lines()const { return lines; }
int Matrix::get_cols()const { return cols; }
void Matrix::print()const {
 
	for (int i = 0; i < lines; i++)
    {        
	  for (int j = 0; j < cols - 1; j++)
	    cout << p[i * cols + j] << ", ";
	  cout << p[i * cols + cols -1] << endl;
	}
}

测试代码:

#include <iostream>
#include "matrix.hpp"

void test()
{
    using namespace std;

    double x[] = { 1, 2, 3, 4, 5, 6 };

    Matrix m1(3, 2); // 创建一个3×2的矩阵
    m1.set(x);       // 用一维数组x的值按行为矩阵m1赋值
    m1.print();      // 打印矩阵m1的值
    cout << "the first line is: " << endl;
    cout << m1.at(0, 0) << " " << m1.at(0, 1) << endl; // 输出矩阵m1第1行两个元素的值
    cout << endl;

    Matrix m2(2, 3);
    m2.set(x);
    m2.print();
    cout << "the first line is: " << endl;
    cout << m2.at(0, 0) << " " << m2.at(0, 1) << " " << m2.at(0, 2) << endl;
    cout << endl;

    Matrix m3(m2);     // 用矩阵m2构造新的矩阵m3
    m3.set(0, 0, 999); // 将矩阵m3第0行第0列元素值设为999
    m3.print();
}

int main()
{
    test();
}

  

更换一组数据:

#include <iostream>
#include "matrix.hpp"

void test()
{
    using namespace std;

    double x[] = { 51, 28, 32, 45, 55, 76 };

    Matrix m1(2, 3); // 创建一个3×2的矩阵
    m1.set(x);       // 用一维数组x的值按行为矩阵m1赋值
    m1.print();      // 打印矩阵m1的值
    cout << "the first line is: " << endl;
    cout << m1.at(0, 0) << " " << m1.at(0, 1) << " " << m1.at(0,2)<<endl; // 输出矩阵m1第1行两个元素的值
    cout << endl;

    Matrix m2(3, 2);
    m2.set(x);
    m2.print();
    cout << "the double line is: " << endl;
    cout << m2.at(2, 0) << " " << m2.at(2, 1) << endl;
    cout << endl;

    Matrix m3(m2);     // 用矩阵m2构造新的矩阵m3
    m3.set(0, 0, 999); // 将矩阵m3第0行第0列元素值设为999
    m3.print();
}

int main()
{
    test();
}

 

标签:const,Matrix,int,double,m1,数组,vectorInt,实验,指针
From: https://www.cnblogs.com/xtc111/p/16863420.html

相关文章

  • 实验环境配置
    一、实验目的熟悉实验环境熟悉Linux基本操作二、实验要求(一)任务请根据实验环境安装文档,完成特定开源软件的安装(二)实验报告请用Markdown排版,提交在博客园班级作......
  • 实验6:开源控制器实践——RYU
    实验6:开源控制器实践——RYU一、实验目的能够独立部署RYU控制器;能够理解RYU控制器实现软件定义的集线器原理;能够理解RYU控制器实现软件定义的交换机原理。二、实验环境......
  • 实验二:逻辑回归算法实验
    【实验目的】1.理解逻辑回归算法原理,掌握逻辑回归算法框架;2.理解逻辑回归的sigmoid函数;3.理解逻辑回归的损失函数;4.针对特定应用场景及数据,能应用逻辑回归算法解决实际分......
  • 实验3
     #include<stdio.h>#include<stdlib.h>#include<time.h>#include<windows.h>#defineN80voidprint_text(intline,intcol,chartext[]);voidprint_......
  • 实验7:基于REST API的SDN北向应用实践
    实验7:基于RESTAPI的SDN北向应用实践一、实验目的能够编写程序调用OpenDaylightRESTAPI实现特定网络功能;能够编写程序调用RyuRESTAPI实现特定网络功能。二、实验环境下......
  • [代码审计]信呼协同办公系统2.2存在文件上传配合云处理函数组合拳RCE
    文章目录​​写在前面​​分析​​​​脚本​​写在前面本次强网杯决赛的一个题,还是蛮有意思的,代码可以在github拿到​​​https://github.com/rainrocka/xinhu​​分析首......
  • 指针+函数解决问题
    问题:交换两个整形的数值#include<stdio.h>voidswap(int*pa, int*pb){inttmp=*pa;*pa=*pb;*pb=tmp;}int main(){int a=45;int b=86;printf("a=%db=%d\n",a,b);sw......
  • 实验1:SDN拓扑实践
    实验1:SDN拓扑实践一、实验目的能够使用源码安装Mininet;能够使用Mininet的可视化工具生成拓扑;能够使用Mininet的命令行生成特定拓扑;能够使用Mininet交互界面管理SDN拓......
  • 实验二
    1.基础要求a)/home/用户名/学号/lab2/目录下执行ovs-vsctlshow命令截图p0和p1连通性测试的执行结果截图b)/home/用户名/学号/lab2/目录下开启MininetCLI并执行pin......
  • 在有序数组中插入一个数后仍然有序
    #include<stdio.h>intmain(){ inta[7]={2,5,12,32,44,57}; intb=20; inti; intj; intlength; length=sizeof(a)/sizeof(int); printf("插......