C++动态分配

设定义一个类:
class ListArray
{
private:
int size; //整型数组的大小,表示可放元素的个数
int elem; //整型数组当前的元素个数,初始应为0,当elem等于size时,数组满
int *p; //指向整型数组,动态分配内存空间
public:
ListArray(int s=100); //用s初始化整型数组的大小
void put(int n); //将n加入整型数组,elem自增1
void print(); //输出整型数组所有元素
~ListArray();
};
请完成该类成员函数的定义和测试程序的设计。

【提示】编写void put(int n)函数时,注意考虑数组满的情况。如果数组已满,则没有空间存储n,此时需动态申请新的内存空间,其大小应比原数组大小大1,并将原数组元素备份到新数组,新数组的最后一个元素存放n,当然不要忘记释放为原数组动态分配的内存空间。


1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
#include <iostream>
using  namespace  std;
 
  class  ListArray
{
    private :
      int  size;    //整型数组的大小,表示可放元素的个数
      int  elem;   //整型数组当前的元素个数,初始应为0,当elem等于size时,数组满
      int  *p;     //指向整型数组,动态分配内存空间
    public :
      ListArray( int  s=100);    //用s初始化整型数组的大小
     void  put( int  n);      //将n加入整型数组,elem自增1
     void  print();          //输出整型数组所有元素
     ~ListArray();
   };
 
//start
ListArray::ListArray( int  s)
{
     size = s;
     elem = 0;
     if (s) p =  new  int  [s];
     else  p = NULL;
}
 
void  ListArray::put( int  n)
{
     int  *t;
     if (p == NULL)
     {
         p =  new  int [1];
         p[0] = n;
         elem = size = 1;
     }
     else
     {
         if (elem == size)
         {
             size ++;
             t =  new  int  [size];
             for ( int  i = 0; i < elem; i ++)
                 t[i] = p[i];
             t[elem ++] = n;
             delete  [] p;
             p = t;
         }
         else  p[elem ++] = n;
     }
}
void  ListArray::print()
{
     for ( int  i = 0; i < elem; i ++)
         cout << p[i] <<  ' ' ;
     cout << endl;
}
ListArray::~ListArray()
{
     if (p)  delete [] p;
}
//end
 
//test code
int  main()
{
     ListArray a(2);
 
     a.put(1);
     a.put(2);
     a.print();
     a.put(3);
     a.print();
     a.put(5);
     a.print();
     return  0;
}

C++中可以使用动态分配的顺序表来实现动态数组,其中vector是C++标准库中提供的一个动态数组容器[^2]。下面是一个使用vector实现动态分配顺序表的示例代码: ```cpp #include <iostream> #include <vector> int main() { std::vector<int> seqList; // 创建一个空的动态分配顺序表 // 在顺序表末尾插入元素 seqList.push_back(10); seqList.push_back(20); seqList.push_back(30); // 获取顺序表的长度 int length = seqList.size(); // 遍历顺序表 for (int i = 0; i < length; i++) { std::cout << seqList[i] << " "; } std::cout << std::endl; // 删除顺序表中的元素 seqList.pop_back(); // 查找顺序表中的元素 int element = 20; auto it = std::find(seqList.begin(), seqList.end(), element); if (it != seqList.end()) { std::cout << "Element " << element << " found at index " << std::distance(seqList.begin(), it) << std::endl; } else { std::cout << "Element " << element << " not found in the sequence list" << std::endl; } return 0; } ``` 这段代码使用了vector容器来实现动态分配顺序表。首先,我们创建了一个空的动态分配顺序表seqList。然后,我们使用push_back函数在顺序表的末尾插入元素。接下来,我们使用size函数获取顺序表的长度,并使用for循环遍历顺序表中的元素。然后,我们使用pop_back函数删除顺序表中的最后一个元素。最后,我们使用find函数查找顺序表中的元素,并使用distance函数计算元素在顺序表中的索引。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值