当前位置: 首页 > article >正文

作业2024/2/5

第四章  堆与拷贝构造函数

 一 、程序阅读题

1、给出下面程序输出结果。

#include <iostream.h>

class example

{int a;

public:

example(int b=5){a=b++;}

void print(){a=a+1;cout <<a<<"";}

void print()const

{cout<<a<<endl;}

};

void main()

{example x;

const example y(2);

x.print();

y.print();

}

6 2

2、运行程序,写出程序执行的结果。

#include<iostream.h>

class Location

{   public:

int X,Y;

void init(int initX,int initY);

int GetX();

int GetY();

};

void Location::init (int initX,int initY)

{X=initX;

Y=initY;

}

int Location::GetX()

{return X;

}

int Location::GetY()

{return Y;

}

void display(Location& rL)

{cout<<rL.GetX()<<" "<<rL.GetY()<<\n;

}

void main()

{

Location A[5]={{5,5},{3,3},{1,1},{2,2},{4,4}};

Location *rA=A;

A[3].init(7,3);

rA->init(7,8);

for (int i=0;i<5;i++)

display(*(rA++));

}

7 8

3 3

1 1

7 3

4 4

3. 给出下面程序输出结果。

#include <iostream.h>

int a[8]={1,2,3,4,5,6,7};

void fun(int *pa,int n);

void main()

{int m=8;

fun(a,m);

cout<<a[7]<<endl;

}

void fun(int *pa,int n)

{for (int i=0;i<n-1;i++)

*(pa+7)+=*(pa+i);

}

28

4. 给出下面程序输出结果。

#include <iostream.h>

class A

{

int *a;

public:

A(int x=0):a(new int(x)){}

~A() {delete a;}

int getA() {return *a;}

void setA(int x) {*a=x;}

};

void main()

{

A x1,x2(3);

A *p=&x2;

(*p).setA(x2.getA()+5);

x1.setA(10+x1.getA());

cout<<x1.getA()<<""<<x2.getA()<<endl;

}

10 8

5. 阅读下面的程序,写出运行结果:

#include < iostream>

using namespace std;

class Samp

{

public:

    void Set_i_j(int a, int b){i=a,j=b;}

    ~Samp()

    {

        cout <<"Destroying.." << i <<endl;

    }

    int GetMulti () { return i * j; }

protected:

int i;

int j;

};

int main ()

{

Samp * p;

p = new Samp[l0];

if(!p)

{

cout << "Allocation error \ n";

return;

}

for(int j =0; j<l0; j ++)

    p[j]. Set_i_j (j, j);

for(int k=0; k<l0; k++)

    cout <<"Multi[" <<k <<"] is:"<< p[k].GetMulti () <<endl;

delete [ ] p;

return 0;

}

Multi[0] is: 0

Multi[1] is: 1

Multi[2] is: 4

Multi[3] is: 9

Multi[4] is: 16

Multi[5] is: 25

Multi[6] is: 36

Multi[7] is: 49

Multi[8] is: 64

Multi[9] is: 81

Destroying..0

Destroying..1

Destroying..2

Destroying..3

Destroying..4

Destroying..5

Destroying..6

Destroying..7

Destroying..8

Destroying..9

 

6. 写出下面程序的运行结果,请用增加拷贝构造函数的方法避免存在的问题。

#include < iostream>

using namespace std;

class Vector

{

public:

    Vector (int s = 100);

    int& Elem(int ndx);

    void Display();

    void Set ();

    ~Vector ();

protected:

int size;

int* buffer;

}

Vector::Vector (int s)

{

buffer = new int [size = s];

for(int i = O; i<size; i + + )

    buffer [i] = i* i;

}

int& Vector:: Elem(int ndx)

{

    if(ndx< 0 || ndx> = size)

    {

        cout << "error in index" <<endl;

        exit (1);

    }

    return buffer [ndx];

}

void Vector::Display ()

{

    for(int j =0; j< size; j ++)

    cout << buffer[j] <<endl;

}

void Vector:: Set ()

{

    for(int j =0; j<size; j++)

        buffer[j] = j + 1;

}

Vector:: ~ Vector()

{

    delete [] buffer;

}

int main()

{

    Vector a(10);

    Vector b(a);

    a. Set ();

    b. Display ();

 

return 0;

}

加的构造函数

#include <iostream>

using namespace std;

class Vector {

public:

    Vector(int s = 100);

    Vector(const Vector& other); // 拷贝构造函数

    int& Elem(int ndx);

    void Display();

    void Set();

    ~Vector();

protected:

    int size;

    int* buffer;

};

Vector::Vector(int s) {

    buffer = new int[size = s];

    for (int i = 0; i < size; i++)

        buffer[i] = i * i;

}

Vector::Vector(const Vector& other) {

    size = other.size;

    buffer = new int[size];

    for (int i = 0; i < size; i++)

        buffer[i] = other.buffer[i];

}

int& Vector::Elem(int ndx) {

    if (ndx < 0 || ndx >= size) {

        cout << "error in index" << endl;

        exit(1);

    }

    return buffer[ndx];

}

void Vector::Display() {

    for (int j = 0; j < size; j++)

        cout << buffer[j] << endl;

}

void Vector::Set() {

    for (int j = 0; j < size; j++)

        buffer[j] = j + 1;

}

Vector::~Vector() {

    delete[] buffer;

}

int main() {

    Vector a(10);

    Vector b(a);

    a.Set();

    b.Display();

    return 0;

}

7.读下面的程序与运行结果,添上一个拷贝构造函数来完善整个程序。

    

#include < iostream>

using namespace std;

class CAT

{

public:

    CAT();

    CAT(const CAT&);

    ~CAT();

    int GetAge() const (return * itsAge;)

    void SetAge(int age) { * itsAge = age; }

protected:

int * itsAge;

};

CAT::CAT ()

{

itsAge = new int;

*itsAge = 5;

}

CAT::~CAT ()

{

    delete itsAge;

    itsAge = 0;

}

void main()

{

    CAT frisky;

    cout << "frisky's age:" << frisky. GetAge() <<endl;

    cout <<"Setting frisky to 6... \ n";

    frisky. SetAge ( 6 );

    cout << "Creating boots from frisky \ n";

    CAT boots(frisky);

    cout <<"frisky's age:" << frisky. GetAge() <<endl;

    cout << "boots'age:" << boons. GetAge () <<endl;

    cout << "setting frisk,, to 7 .... n";

    frisky. SetAge (7);

    cout <<"frisky"s age:" << frisky. GetAge() <<endl;

    cout <<"boots' age:" << boots. GetAge() <<endl;

}

 

运行结果为:

    frisky's age:5

    Setting frisky to 6...

    Creating boots from frisky

    frisky's age:6

    boots' age:6

    Setting frisky to 7...

    frisky's age:7

    boots' age:6

添加

CAT::CAT(const CAT& other) {

    itsAge = new int;

    *itsAge = *other.itsAge;

}

CAT::~CAT() {

    delete itsAge;

    itsAge = 0;

}


http://www.kler.cn/a/229687.html

相关文章:

  • 【YOLOv5】源码(train.py)
  • MySQL存储引擎、索引、索引失效
  • Spring——自动装配
  • Javaweb之SpringBootWeb案例之 登录功能的详细解析
  • 人工智能深度学习发展历程-纪年录
  • 来看看Tomcat和Web应用的目录结构
  • 数据分析基础之《pandas(5)—文件读取与存储》
  • GPT-1, GPT-2, GPT-3, GPT-3.5, GPT-4论文内容解读
  • [香橙派开发系列]使用蓝牙和手机进行信息的交换
  • Redis(十三)缓存双写一致性策略
  • 《【python】staticmethod与classmethod深度机制解析——要知其所以然》学习笔记
  • 十六、Vben框架table内部合并行
  • 88 SRC挖掘-拿下CNVD证书开源闭源售卖系统
  • 倒计时64天
  • 肯尼斯·里科《C和指针》第12章 使用结构和指针(1)链表
  • SpringBoot:配置相关知识点
  • nginx upstream server主动健康检测模块ngx_http_upstream_check_module 使用和源码分析(上)
  • pytorch的安装步骤
  • QT Linux下无法使用CTRL+ALT+P快捷键,不生效
  • 华为云账号注销之后账号下的域名丢了怎么办?记录一次域名转移权限的经历
  • Dijkstra算法(求最短路)
  • 算法刷题day06
  • 什么是大模型