C++第七章 动态内存分配习题解答

合集下载

c语言的动态内存分配题目

c语言的动态内存分配题目

以下是一个使用C语言动态内存分配的题目示例:
题目:给定一个长度为n的整数数组,要求将其划分为若干个长度为k的连续子数组,使得所有子数组的和尽可能接近。

请你实现一个函数,返回划分后的所有子数组的最大和。

示例输入:
输入:n = 5, k = 2
输出:8
解释:将数组[1, 2, 3, 4, 5] 划分为[1, 2], [3, 4], [5] 三个子数组,它们的和分别为3, 7, 5,和为15,接近于最大和。

实现这个函数可以使用动态规划的思想。

首先定义一个长度为n的数组dp,其中dp[i]表示以第i个元素结尾的子数组的最大和。

然后从左到右遍历数组,对于每个位置i,计算dp[i]的值。

如果i-1位置的子数组和大于0,则将dp[i]设置为dp[i-1]加上当前元素的值;否则,将dp[i]设置为当前元素的值。

最后返回dp[n-1]即可。

C语言程序设计教程 第七章 课后习题参考答案

C语言程序设计教程 第七章 课后习题参考答案
for(i=0;i<M;i++)
{
for(j=0;j<N;j++)
{
printf("%4d",a[i][j]);
}
printf("\n");
}
for(i=0;i<M;iபைடு நூலகம்+)
{
for(j=0;j<N;j++)
{
if(i==j)
m+=a[i][j];
}
}
printf("主对角线元素之和为:%d\n",m);
批注本地保存成功开通会员云端永久保存去开通
P198 3求主、副对角线元素之和
#include<stdio.h>
#define M 4
#define N 4
int main()
{
int a[M][N]={1,2,3,4,5,6,7,8,9,10,11,12,13,14,15,16};
int i,j,m=0,n=0;
{
if(a[j]>a[j+1])
{
tmp=a[j];
a[j]=a[j+1];
a[j+1]=tmp;
}
}
}
printf("\n");
printf("排序后的数组为:\n");
for(i=0;i<N;i++)
{
printf("%4d",a[i]);
}
}
P76 3成绩
#include<stdio.h>
void input(int cla[50][3],int n);

《C语言程序设计教程》第三版课后习题参考答案

《C语言程序设计教程》第三版课后习题参考答案

《C语言程序设计教程》第三版课后习题参考答案C语言程序设计教程第三版课后习题参考答案第一章:C语言概述1.1 C语言的特点答案:C语言是一种通用的、面向过程的程序设计语言,具有高效、简洁、灵活等特点。

它提供了丰富的程序设计元素和功能,适用于各种不同的应用领域。

1.2 C语言程序的基本结构答案:C语言程序由预处理指令、函数声明、函数定义、变量声明和语句组成。

其中,预处理指令用来引入头文件或定义宏,函数声明用来声明函数的名称和参数,函数定义用来实现函数的功能,变量声明用来声明变量的类型和名称,语句用来表达具体的计算过程。

1.3 C语言的数据类型答案:C语言提供了多种数据类型,包括基本类型(整型、浮点型、字符型等)和派生类型(数组、指针、结构体等)。

每种数据类型在内存中占据一定的存储空间,并具有特定的取值范围和操作规则。

1.4 C语言的运算符和表达式答案:C语言支持各种运算符和表达式,例如算术运算符(+、-、*、/等)、关系运算符(>、<、==等)、逻辑运算符(&&、||、!等)等。

通过运算符和表达式可以进行各种数值计算和逻辑判断。

第二章:基本数据类型与运算2.1 整型数据类型答案:C语言提供了不同长度的整型数据类型,包括有符号整型(int、long等)和无符号整型(unsigned int、unsigned long等)。

整型数据类型可以表示整数值,并具有不同的取值范围。

2.2 浮点型数据类型答案:C语言提供了浮点型数据类型(float、double等),用来表示带小数部分的实数值。

浮点型数据可以表示较大或较小的数值,并具有一定的精度。

2.3 字符型数据类型答案:C语言提供了字符型数据类型(char),用来表示单个字符。

字符型数据可以用于表示各种字符(包括字母、数字、符号等)。

2.4 布尔型数据类型答案:C语言不直接支持布尔型数据类型,但可以使用整型数据类型来表示布尔值(0表示假、非零表示真)。

《动态分配内存与数据结构》课后习题(含答案)

《动态分配内存与数据结构》课后习题(含答案)

6、分析下列代码是否存在问题,选择合适的选项: int main(void) { int *p = new int [10]; p = new int [10]; delete [] p; p = NULL; return 0; } A.没有问题 C.存在空悬指针
B.有内存泄漏 D.存在重复释放同一空间 D 。 D.堆区
3、写出程序的运行结果 #include <iostream> #include <string> using namespace std; template <typename T> class Node { public: T data; Node<T> *link; Node(const T&info) {data=info;link=NULL;} }; template <typename T> class OrderedLink { Node<T> *head; public: OrderedLink() {head=NULL;} OrderedLink(const T*list,int num) { head = NULL;
B. p->next=r; q->next=r->next; r->next=q; C. q->next=r->next; r->next=q; p->next=r; D. r->next=q; p->next=r; q->next=r->next; 二、填空题 1、在长度为 10 的顺序存储的线性表中插入一个元素,最坏情况下需要移动表 中 10 个元素。
2、 设某循环队列的容量为 40, 头指针 front=3 (指向队头元素的前一位置) , 尾指针 rear=25 (指向队尾元素),则该循环队列中共有 22 个元素。

C语言内存分配问题(整理)

C语言内存分配问题(整理)
程序代码区:用来存放程序的二进制代码。
我查了下资料,有说分四个,有说分五个加一个程序代码区,我没查到参考的专业书籍。所 以麻烦知道的告知一下,完善一下。
2、 内存分配方式 内存分配方式有三种:
1)从静态存储区域分配。内存在程序编译的时候就已经分配好,这块内存在程序的整 个运行期间都存在。例如全局变量,static 变量。
4、动态分配释放内存举例 用 malloc 动态分配内存后一定要判断一下分配是否成功,判断指针的值是否为 NULL。 内存分配成功后要对内存单元进行初始化。 内存分配成功且初始化后使用时别越界了。 内存使用完后要用 free(p)释放,注意,释放后,p 的值是不会变的,仍然是一个地址值, 仍然指向那块内存区,只是这块内存区的值变成垃圾了。为了防止后面继续使用这块内存, 应在 free(p)后,立即 p=NULL,这样后面如果要使用,判断 p 是否为 NULL 时就会判断出 来。
NO.2
char *GetMemory(void) {
char Байду номын сангаас[] = hello world; retrun p; } void Test(void) { char *str = NULL; str = GetMemory(); printf(str); }
问题同 NO.1
NO.3
void GetMemory(char **p, int num) {
free(str); if(str != NULL) {
strcpy(str,"world"); printf(str); } }
问题同 NO.1 我对以上问题的分析:
NO.1:程序首先申请一个 char 类型的指针 str,并把 str 指向 NULL(即 str 里存的是 NULL 的地址,*str 为 NULL 中的值为0),调用函数的过程中做了如下动作: 1、申请一个 char 类型的指针 p, 2、把 str 的内容 copy 到了 p 里(这是参数传递过程中系统所做的), 3、为 p 指针申请了 100 个空间, 4、返回 Test 函数.最后程序把字符串 hello world 拷贝到 str 指向的内存空间里.到这里错 误出现了! str 的空间始终为 NULL 而并没有实际的空间.深刻理解函数调用的第 2 步,将不难发现问 题所在!(注意:传递的参数和消除的参数) NO.2:程序首先申请一个 char 类型的指针 str,并把 str 指向 NULL.调用函数的过程中做了 如下动作: 1申请一数组 p[]并将其赋值为 hello world(数组的空间大小为 12), 2返回数组名 p 付给 str 指针(即返回了数组的首地址). 那么这样就可以打印出字符串"hello world"了么?当然是不能的! 因为在函数调用的时候漏掉了最后一步.也就是在第2步 return 数组名后,函数调用还要 进行一步操作,也就是释放内存空间.当一个函数被调用结束后它会释放掉它里面所有的变 量所占用的空间.所以数组空间被释放掉了,也就是说 str 所指向的内容将不确定是什么东 西. NO.3:正确答案为可以打印出 hello.但内存泄漏了! 需要用 free()函数进行释放。

7C++动态存储分配

7C++动态存储分配

int main() { Vector v1; //空的向量,无元素 Vector v2(5); //有5个元素的向量,每个元素值为0 Vector v3(5,9);//有5个元素的向量,每个元素值为9 v2.print(); v3.print(); v3.at(2) = 88; //等价于v3[2] = 88; v3.print(); cout << "v3[2] = " << v3.at(2) << endl; if(v1.isEmpty()) cout << "向量为空!" << endl; else cout << "向量不为空!" << endl; cout << "length of v2 is : " << v2.length() << endl; Vector v4(v3); v4.print(); return 0; }

基本类型一般不采用动态存储分配
7
2013-12-16
动态存储空间的回收
用new分配的空间一定要用delete回收 具体使用格式: – delete 指针变量名

– delete[] 指针变量名 //用于动态数组的内存回收 delete只能用于回收new所分配的空间 对于一个指针指向的堆对象只能执行一次 delete操作 delete[]忽略括符内的具体数字,无论是几维数 组的空间回收均只用一个括符表示
21
复制构造函数

主要功能 :
– 用一个已知的对象来初始化一个同类对象

具体声明格式: <类名>::<类名> (const <类名>& <对象名>) 复制构造函数只有一个参数,是该类对象的引用 若用户没有显式定义复制构造函数,编译器会自 动生成一个默认的复制构造函数,其功能是把已 知对象的每个数据成员都复制到新定义的对象中

c语言课后复习题答案

c语言课后复习题答案

c语言课后复习题答案1. 请解释C语言中变量的作用域和生命周期。

在C语言中,变量的作用域指的是变量可以被访问的代码区域。

局部变量的作用域仅限于定义它的函数或代码块内部,而全局变量的作用域是整个程序。

变量的生命周期是指变量从被创建到被销毁的时间。

局部变量的生命周期从定义它的地方开始,到包含它的函数或代码块结束时结束。

全局变量的生命周期从程序开始执行时创建,到程序结束时销毁。

2. 描述C语言中指针和数组的关系。

在C语言中,指针是一种特殊的变量,它存储了另一个变量的内存地址。

数组名可以被看作是一个常量指针,它指向数组的第一个元素的地址。

通过指针运算,可以访问数组的任意元素。

例如,如果有一个数组`int arr[5];`,那么`arr`指向数组的第一个元素,`arr+1`指向第二个元素,以此类推。

3. 说明C语言中结构体和联合体的区别。

结构体(struct)和联合体(union)都是C语言中用于创建复杂数据类型的复合数据类型。

结构体可以包含不同类型的数据成员,并且每个成员都有自己的内存空间。

联合体则是一种特殊的数据类型,它允许在相同的内存位置存储不同的数据类型,但是任何时候只能存储其中一个成员的值。

结构体和联合体的主要区别在于内存的使用方式和数据的存储方式。

4. 列举C语言中常用的输入输出函数。

C语言中常用的输入输出函数包括`printf()`和`scanf()`用于标准输入输出,`getchar()`和`putchar()`用于单个字符的输入输出,以及`fgets()`和`fputs()`用于字符串的输入输出。

此外,还有`fopen()`、`fclose()`、`fread()`和`fwrite()`等用于文件操作的函数。

5. 解释C语言中的递归函数。

递归函数是一种调用自身的函数。

在C语言中,递归函数通常用于解决可以分解为相似子问题的问题,如计算阶乘、进行排序等。

递归函数需要有一个明确的结束条件,以避免无限递归。

编译预处理和动态存储分配及答案

编译预处理和动态存储分配及答案

编译预处理和动态存储分配及答案编译预处理和动态存储分配一、选择题(1)有以下程序 main(){ char p[]={'a', 'b', 'c'}, q[]=\ printf(\ %d\\n\ };程序运行后的输出结果是 A)4 4 B)3 3 C)3 4 D)4 3(2)有以下程序# define f(x) (x*x) main(){ int i1, i2;i1=f(8)/f(4) ; i2=f(4+4)/f(2+2) ; printf(\ }程序运行后的输出结果是 A)64, 28 B)4, 4 C)4, 3 D)64, 64(3)有以下程序 main(){ char a[7]=\ i,j; i=sizeof(a); j=strlen(a); printf(\ %d\\n\}程序运行后的输出结果是 A)2 2 B)7 6 C)7 2 D)6 2(4)以下叙述中正确的是 A)预处理命令行必须位于源文件的开头B)在源文件的一行上可以有多条预处理命令 C)宏名必须用大写字母表示 D)宏替换不占用程序的运行时间(5) 有以下程序 main( ){ char a[]=”abcdefg”,b[10]=”abcdefg”;printf(“%d %d\\n”,sizeof(A) ,sizeof(B) ); }执行后输出结果是 A) 7 7 B) 8 8 C) 8 10 D) 10 10(6) 有以下程序#define f(x) x*x main( ) { int i;i=f(4+4)/f(2+2); printf(“%d\\n”,i); }执行后输出结果是 A) 28 B) 22 C) 16 D) 4(7) 有以下程序 #include #define F(X,Y) (X)*(Y) main (){ int a=3, b=4;printf(\}程序运行后的输出结果是 A) 12 B) 15 C) 16 D) 20(8) 有以下程序main(){ char s[]=\printf(\}执行后输出结果是A) 赋初值的字符串有错 B) 6,7 C) 5,6 D) 6,6(9) 有以下程序main(int arge,char *argv[]) { int n,i=0; while(arv[1][i]!='\\0'{ n=fun(); i++;} printf(%d\\n\}int fun(){ static int s=0; s+=1; return s; }假设程序经编译、连接后生成可执行文件exam.exe,若键入以下命令行 exam 123 则运行结果为(10) 有以下程序 main(){ char a[ ]={‘a’,‘b’,‘c’,‘d’, ‘e’, ‘f’, ‘g’,‘h’,‘\\0’};inti=sizeof(a); j=strlen(a); printf(“%d,%d\\b”i,j); }程序运行后的输出结果是 A)9,9 B)8,9 C)1,8 D)9,8(11) 程序中头文件typel.h 的内容是: #define N 5 #define M1 N*3 程序如下:i,j; #define “type1.h” #define M2 N*2 main() { int i;i=M1+M2; printf(“%d\\n”,i); }程序编译后运行的输出结果是: A) 10 B) 20 C) 25 D) 30(12) 有以下程序 #include main() { char *p,*q;p=(char*)malloc(sizeof(char)*20); q=p; scanf(“%s%s”,p,q);printf(“%s%s\\n”,p,q); }若从键盘输入:abc def,则输出结果是: A) def def B) abc def C) abc d D) d d(13) 若指针p已正确定义,要使p指向两个连续的整型动态存储单元,不正确的语句是 A) p=2*(int*)malloc(sizeof(int)); B) p=(int*)malloc(2*sizeof(int)); C) p=(int*)malloc(2*2);D) p=(int*)calloc(2,sizeof(int));(14) 以下程序的输出结果是 main(){ char st[20]= “hello\\0\\t\\\\\\”; printf(%d %d\\n”,strlen(st),sizeof(st)); }A) 9 9 B) 5 20C) 13 20 D) 20 20(15) 以下程序的输出结果是amovep(int p, int (a)[3],int n) { int i, j; for( i=0;i 感谢您的阅读,祝您生活愉快。

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

第七章动态内存分配习题
一、基本概念与基础知识自测题
7.1 填空题
7.1.1 C/C++定义了4个内存区间:(1)、(2)、(3)和(4)。

答案:(1)代码区,存放程序代码;
(2)全局变量与静态变量区,存放全局变量或对象(包括静态);
(3)局部变量区即栈(stack)区,存放局部变量;
(4)动态存储区,即堆(heap)区或自由存储区(free store)。

7.1.2 静态定义的变量和对象用标识符命名,称为(1);而动态建立的称为(2),动
态建立对象的初始化是通过(3)来(4)。

答案:(1)命名对象
(2)无名对象
(3)初始化式(initializer)
(4)显式初始化
7.1.4 当动态分配失败,系统采用(1)来表示发生了异常。

如果new返回的指针丢失,
则所分配的堆空间无法收回,称为(2)。

这部分空间必须在(3)才能找回,这是因为无名对象的生命期(4)。

答案:(1)返回一个空指针(NULL)
(2)内存泄漏
(3)重新启动计算机后
(4)并不依赖于建立它的作用域
7.1.5 按语义的缺省的构造函数和拷贝构造赋值操作符实现的拷贝称(1),假设类对象
obj中有一个数据成员为指针,并为这个指针动态分配一个堆对象,如用obj1按成员语义拷贝了一个对象obj2,则obj2对应指针指向(2)。

答案:(1)浅拷贝
(2)同一个堆对象
7.2简答题(以下习题题号可能和教材不一致!)
7.2.1用delete删除p所指向的无名对象时,p指针也同时被删除了,对不对?为什么?答:不对。

注意这时释放了p所指向的无名对象占用的内存空间,也就是撤销了该无名对象,称动态内存释放(dynamic memory deallocation),但指针p本身并没有撤销,它仍然存在,该指针所占内存空间并未释放。

7.2.2为什么动态建立类对象数组时,类的定义一定要有缺省的构造函数?
答:new后面类(class)类型也可以有参数。

这些参数即构造函数的参数。

但对创建数组,没有参数,只能调用缺省的构造函数。

7.2.3要实现深拷贝,自定义的拷贝构造函数应该怎样设计?
答:如果类中有一个数据成员为指针,该类的一个对象中的这个指针p,指向了动态分配的一个堆对象。

深拷贝时要给新建立的对象独立分配一个堆对象。

这时拷贝的构造函数应
该设计为:先拷贝对象主体,再为新建对象的指针分配一个堆对象,最后用原对象的堆对象拷贝新对象的堆对象。

即分三步完成。

相关文档
最新文档