C面试题基础

合集下载

c面试题及答案

c面试题及答案

c面试题及答案一、题目描述在C语言的面试中,经常会涉及一些基本的概念和问题。

本文将介绍一些常见的C面试题,并提供相应的答案。

二、数据类型与变量1. 请解释C语言中的基本数据类型。

答:C语言中的基本数据类型包括整型、浮点型、字符型和布尔型。

其中,整型可以分为有符号整型和无符号整型;浮点型用于表示带小数点的数值;字符型用于表示单个字符;布尔型用于表示逻辑值,其值可以是真(非零)或假(零)。

2. 如何定义一个整型变量?答:可以使用关键字int加变量名来定义一个整型变量,例如:int num;3. 如何定义一个浮点型变量?答:可以使用关键字float或double加变量名来定义一个浮点型变量,例如:float price;4. 如何定义一个字符型变量?答:可以使用关键字char加变量名来定义一个字符型变量,例如:char ch;5. 如何定义一个布尔型变量?答:在C语言中,没有直接定义布尔型变量的关键字。

通常使用int类型来表示布尔型,0表示假,非零表示真,例如:int flag;三、函数与指针1. 什么是函数?答:函数是一个具有特定功能的代码模块,通过调用函数可以实现特定的操作。

函数有输入和输出,可以接受参数,执行一系列操作后返回结果。

2. 如何定义并调用一个函数?答:函数的定义包括函数的返回类型、函数名、参数列表和函数体。

例如:int add(int a, int b){ return a + b; }。

函数的调用通过函数名加参数列表的形式完成,例如:int result = add(3, 5);3. 什么是指针?答:指针是一个用于存储内存地址的变量。

通过指针可以访问和操作内存中的数据。

4. 如何定义一个指针变量?答:可以使用关键字加变量名的形式来定义一个指针变量。

例如:int *ptr;5. 如何通过指针修改变量的值?答:可以使用解引用操作符(*)来访问指针指向的内存地址中的值,从而修改变量的值。

c语言面试题目100及最佳答案精选全文

c语言面试题目100及最佳答案精选全文

精选全文完整版(可编辑修改)c语言面试题目及最佳答案1、描述⼀下gcc的编译过程?gcc编译过程分为4个阶段:预处理、编译、汇编、链接。

预处理:头⼀件包含、宏替换、条件编译、删除注释编译:主要进⼀词法、语法、语义分析等,检查⼀误后将预处理好的⼀件编译成汇编⼀件。

汇编:将汇编⼀件转换成⼀进制⼀标⼀件链接:将项⼀中的各个⼀进制⼀件+所需的库+启动代码链接成可执⼀⼀件2、内存的最⼀存储单位以及内存的最⼀计量单位分别是?内存的最⼀存储单位为⼀进制位,内存的最⼀计量单位字节3、#include<> 与#include ""的区别?include<>到系统指定⼀录寻找头⼀件,#include ""先到项⼀所在⼀录寻找头⼀件,如果没有找再到系统指定的⼀录下寻找4、描述⼀下变量的命名规则变量名有字⼀、数值、下划线组成,但不能以数值开头5、变量的声明与定义有啥区别?声明变量不需要建⼀存储空间,变量的定义需要建⼀存储空间6、谈谈c语⼀中有符号和⼀符号的区别?有符号:数据的最⼀位为符号位,0表示正数,1表示负数⼀符号:数据的最⼀位不是符号位,⼀是数据的⼀部分7、谈谈计算机中补码的意义统⼀了零的编码将符号位与其他位统⼀处理将减法运算转换成加法运算8、谈谈数组的特点同⼀个数组所有的成员都是相同的数据类型,同时所有的成员在内存中的地址是连续的9、数组的分类数组的分类主要是:静态数组、动态数组两类。

静态数组:类似int arr[5];在程序运⼀就确定了数组的⼀⼀,运⼀过程不能更改数组的⼀⼀。

动态数组:主要是在堆区申请的空间,数组的⼀⼀是在程序运⼀过程中确定,可以更改数组的⼀⼀。

10、描述⼀下⼀维数组的不初始化、部分初始化、完全初始化的不同点不初始化:如果是局部数组数组元素的内容随机如果是全局数组,数组的元素内容为0 部分初始化:未被初始化的部分⼀动补0完全初始化:如果⼀个数组全部初始化可以省略元素的个数数组的⼀⼀由初始化的个数确定11、谈谈数组名作为类型、作为地址、对数组名取地址的区别?数组名作为类型:代表的是整个数组的⼀⼀数组名作为地址:代表的是数组⼀元素的地址对数组名取地址:代表的是数组的⼀地址12、谈谈你对⼀维数组在物理上以及逻辑上的数组维度理解⼀维数组在逻辑上是⼀维的,在物理上是⼀维的13、描述⼀下函数的定义与函数的声明的区别函数定义:是指对函数功能的确⼀,包括指定函数名、函数类型、形参及其类型、函数体等,它是⼀个完整的、独⼀的函数单位。

c语言 面试题

c语言 面试题

c语言面试题C语言面试题C语言是一种广泛应用于系统编程和嵌入式开发领域的计算机编程语言。

如果你正在准备面试,那么掌握一些常见的C语言面试题是非常重要的。

本文将为你提供一些常见的C语言面试题,帮助你更好地准备面试。

一、基础知识类题目1. 什么是C语言?请简要介绍一下C语言的特点。

2. C语言中的标识符和关键字有什么区别?3. C语言中的数据类型有哪些?请列举并简要描述每种数据类型的特点。

4. 请解释一下指针的概念,并说明指针和数组之间的关系。

5. 什么是宏定义?请举一个宏定义的例子并说明其作用。

二、语法类题目1. 请解释一下C语言中的条件语句和循环语句,并举例说明。

2. 如何在C语言中定义一个函数?并简要说明函数的作用。

3. C语言中有哪些类型的运算符?请举例说明每种运算符的用法。

4. 请解释一下C语言中的结构体,并说明如何定义和使用结构体。

5. 什么是递归函数?请给出一个递归函数的例子并说明其执行过程。

三、面向对象编程类题目1. C语言是否支持面向对象编程?请说明理由。

2. 请简要介绍一下C语言中的封装、继承和多态的概念。

3. 在C语言中如何实现封装?请给出一个封装的例子,并说明每个部分的作用。

4. 请解释一下C语言中的函数指针,并说明函数指针和回调函数之间的关系。

5. 如何模拟实现C语言中的继承和多态特性?请给出一个示例。

四、内存管理类题目1. 什么是内存泄漏?请举一个例子,并说明如何避免内存泄漏。

2. 在C语言中如何申请和释放内存?请给出相应的代码示例。

3. 请解释一下C语言中的堆和栈,并说明它们的区别和用途。

4. 如何实现动态内存分配和动态数组的功能?请给出一个示例。

5. 请解释一下C语言中的内存对齐和内存对齐规则。

五、文件处理类题目1. 请简要介绍一下C语言中的文件处理机制。

2. 如何在C语言中打开和关闭文件?请给出相应的代码示例。

3. 如何读取和写入文件中的数据?请给出相应的代码示例。

c语言常见面试题

c语言常见面试题

c语言常见面试题C语言作为一种广泛应用于软件开发领域的编程语言,在面试中往往是必考的内容。

掌握常见的C语言面试题是提升自己竞争力的重要一环。

本文将为您介绍一些常见的C语言面试题,以便在求职面试中能够准备充分。

一、C语言基础知识1. 什么是C语言?C语言是一种通用的、过程式的编程语言,由贝尔实验室的Dennis Ritchie于1972年开发。

C语言以其简洁高效的特点成为软件开发的重要基础。

2. C语言的特点有哪些?C语言具有高效、灵活、可移植、功能强大等特点。

其底层控制能力和丰富的函数库使得C语言能够用于系统级开发和嵌入式开发。

3. 请解释C语言中的变量和常量。

变量是用于存储数据的一种数据类型,在程序运行时可以被修改。

常量是程序中的固定值,不可被修改。

4. C语言中数据类型的分类有哪些?C语言的数据类型包括基本数据类型(如整型、浮点型、字符型)、派生数据类型(如数组、结构体、共用体)和空类型(如指针、枚举)。

5. 什么是C语言的运算符?C语言的运算符用于执行各种数学和逻辑运算。

常见的C语言运算符有算术运算符、关系运算符、逻辑运算符、位运算符等。

二、C语言语法和控制流1. 什么是C语言中的条件控制结构?C语言的条件控制结构包括if语句和switch语句,用于根据条件来选择执行不同的代码块。

2. 请解释C语言中的循环控制结构。

C语言中的循环控制结构包括for循环、while循环和do-while循环,用于重复执行一段代码。

3. C语言中如何定义和使用函数?在C语言中,函数是一段完成特定任务的代码块。

定义函数需要指定函数名、返回值类型、参数列表和函数体。

可以通过函数名和参数列表来调用函数并执行其中的代码。

4. 请解释C语言中的指针。

指针是C语言中的一种特殊变量,用于存储其他变量的内存地址。

通过指针可以直接访问或修改目标变量的值。

三、C语言内存管理和文件操作1. 什么是动态内存分配?动态内存分配是指程序运行过程中根据需要在堆中分配空间。

c语言复试面试题目

c语言复试面试题目

1、在C语言中,以下哪个关键字用于定义一个结构体类型?A. classB. structC. unionD. enum(答案)B2、关于C语言的指针,以下说法错误的是?A. 指针是存储变量地址的变量B. 指针可以进行加减运算,但结果仍然是地址C. 空指针不指向任何有效的内存地址D. 指针变量的类型决定了它可以指向的变量类型及占用的内存大小(答案)D3、在C语言中,若要使用标准输入输出库函数,必须包含哪个头文件?A. <stdio.h>B. <stdlib.h>C. <string.h>D. <math.h>(答案)A4、以下哪个不是C语言的基本数据类型?A. intB. floatC. charD. string(答案)D5、在C语言中,数组名作为函数参数时,传递的是?A. 数组的第一个元素的值B. 数组所有元素的值C. 数组第一个元素的地址D. 数组的长度(答案)C6、关于C语言的循环结构,以下说法正确的是?A. while循环和do-while循环至少执行一次循环体B. for循环中的初始化表达式可以省略,但循环条件表达式和循环后表达式不能省略C. 三种循环结构(while, do-while, for)完全可以相互替代,没有区别D. 在任何情况下,for循环都可以被while循环替代,但反之不然(答案)D(注:虽然D 选项在技术上不完全准确,因为有些情况下for循环的简洁性是不可替代的,但从循环功能上来看,for循环能做的事情while循环也能做到,只是可能更冗长。

这里选择D作为最接近正确的答案。

)8、关于C语言的函数,以下说法错误的是?A. 每个函数都可以有返回值,返回值类型由函数声明时指定B. 函数可以有参数,参数列表在函数名后的括号内指定C. main函数是C程序的入口点D. 在一个C程序中,可以定义多个同名但参数列表不同的函数(答案)A(注:A选项错误在于并非每个函数都必须有返回值,void类型的函数就没有返回值。

c语言相关的基础面试题

c语言相关的基础面试题

c语言相关的基础面试题
以下是一些C语言相关的面试题,这些问题可以帮助你了解应聘者是否熟悉C语言的基本概念和编程技巧:
1. C语言有哪些基本的数据类型?
2. 什么是常量?什么是变量?请举例说明。

3. 如何在C语言中声明一个变量?
4. C语言中的运算符有哪些?请简要说明它们的优先级。

5. 请解释一下C语言中的指针是什么,以及如何声明和使用指针变量。

6. C语言中的函数是如何定义的?能否提供一个函数定义的例子?
7. C语言中如何实现数组的排序?
8. 请解释一下C语言中的结构体是什么,以及如何声明和使用结构体变量。

9. 什么是C语言的递归函数?请举一个例子来说明递归函数的实现。

10. C语言中的main函数是什么?它的作用是什么?
11. C语言中的内存管理是如何实现的?
12. C语言中的指针和数组有哪些关系?
13. C语言中的位运算符有哪些?它们的作用是什么?
14. 如何使用C语言中的条件语句(if-else)和循环语句(for、while)?
15. C语言中的文件操作是如何实现的?请简要说明一下文件操作的步骤。

16. C语言中的内存泄漏是什么?如何避免内存泄漏?
17. 什么是C语言中的宏定义?如何使用宏定义来优化代码?
18. 请解释一下C语言中的静态变量和全局变量。

19. 如何使用C语言中的函数指针来调用函数?
20. 请解释一下C语言中的链表是什么,以及如何操作链表。

c面试题及答案

c面试题及答案

c面试题及答案1. 什么是C语言中的指针?指针是一个变量,其值为另一个变量的地址。

在C语言中,指针变量存储的是内存地址,而不是数据值。

2. 解释C语言中的数组和指针的关系。

数组名本身可以作为指向数组第一个元素的指针。

因此,数组名可以用于指针运算。

3. 如何在C语言中定义一个结构体?在C语言中,可以通过以下方式定义一个结构体:```cstruct 结构体名称 {数据类型成员1;数据类型成员2;...数据类型成员n;};```4. 描述C语言中的函数原型。

函数原型是函数声明的格式,它告诉编译器函数的名称、返回类型、参数类型和数量。

例如:```c返回类型函数名(参数类型参数1, 参数类型参数2, ...);```5. 解释C语言中的递归函数。

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

它必须有一个退出条件,否则会导致无限递归。

6. 如何在C语言中实现文件操作?在C语言中,可以使用标准库中的文件操作函数,如`fopen`、`fclose`、`fread`、`fwrite`等,来实现文件的打开、关闭、读取和写入。

7. 什么是C语言中的预处理器指令?预处理器指令是编译器在编译程序之前执行的命令。

常见的预处理器指令包括`#include`、`#define`、`#ifdef`等。

8. 解释C语言中的内存分配。

C语言中可以使用`malloc`和`calloc`函数从堆内存分配内存,使用`free`函数释放内存。

9. 在C语言中如何实现多线程编程?C语言可以通过使用POSIX线程(pthread)库来实现多线程编程。

10. 描述C语言中的位运算符。

位运算符包括`&`(按位与)、`|`(按位或)、`^`(按位异或)、`~`(按位取反)、`<<`(左移)、`>>`(右移)。

11. 如何在C语言中使用宏定义?宏定义是通过`#define`预处理器指令实现的。

例如:```c#define 宏名宏体```12. 解释C语言中的静态存储类别。

c语言面试题集(完整版)

c语言面试题集(完整版)

c语言面试题集(完整版)试题1:C语言面试题一——华为篇1.static有什么用途?(请至少说明两种)1)限制变量的作用域2)设置变量的存储域(堆,主动分配内存也是堆)2.引用与指针有什么区别?1) 引用必须被初始化,指针不必。

2) 引用初始化以后不能被改变,指针可以改变所指的对象。

3) 不存在指向空值的引用,但是存在指向空值的指针。

3.描述实时系统的基本特性在特定时间内完成特定的任务,实时性与可靠性4.全局变量和局部变量在内存中是否有区别?如果有,是什么区别?全局变量储存在静态数据库,局部变量在栈5.什么是平衡二叉树?左右子树都是平衡二叉树且左右子树的深度差值的绝对值不大于16.堆栈溢出一般是由什么原因导致的?没有回收垃圾资源7.什么函数不能声明为虚函数?constructor (构造函数)8.冒泡排序算法的时间复杂度是什么?(其它排序算法的时间复杂度) O(n^2)9.写出float x 与“零值”比较的if语句。

if(x>0.000001&&x<-0.000001)10.Internet采用哪种网络协议?该协议的主要层次结构?tcp/ip 应用层/传输层/网络层/数据链路层/物理层11.Internet物理地址和IP地址转换采用什么协议?ARP (Address Resolution Protocol)(地址解析協議)18.IP地址的编码分为哪俩部分?IP地址由两部分组成,网络号和主机号。

不过是要和“子网掩码”按位与上之后才能区分哪些是网络位哪些是主机位。

19.用户输入M,N值,从1至N开始顺序循环数数,每数到M输出该数值,直至全部输出。

写出C程序。

循环链表,用取余操作做#include <stdio.h>#define NULL 0#define TYPE struct stu#define LEN sizeof (struct stu)struct stu{int data;struct stu *next;};TYPE *line(int n){int sum=1;struct stu *head,*pf,*pb;int i;for(i=0;i<n;i++){pb=(TYPE*) malloc(LEN);pb->data=sum;if (i==0)pf=head=pb;elsepf->next=pb;if (i==(n-1))pb->next=head;else pb->next=NULL;pf=pb;sum++;}return(head);}main(){int M,N,x,i;struct stu *p,*q;printf("please scanf M and N (M<N)");scanf("%d %d",&M,&N);p=line(N);x=N;while(x){for(i=1;i<M-1;i++){p=p->next;}q=p->next;printf("%d\n",q->data) ;p->next = p->next->next;p=p->next;free(q) ;x--;}getch();}20.不能做switch()的参数类型是:switch的参数不能为实型。

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

1.const符号常量:(1)、const char *p(2)、char const *p(3)、char * const p如果const位于星号的左侧,则const就是用来修饰指针所指向的变量,即指针指向为常量。

如果const位于星号的右侧,const就是修饰指针本身,即指针本身是常量。

2.析构函数和虚函数的用法和作用?析构函数的作用是当对象生命期结束时释放对象所占用的资源。

析构函数用法:析构函数是特殊的类成员函数它的名字和类名相同,没有返回值,没有参数不能随意调用也没有重载。

只是在类对象生命期结束时有系统自动调用。

虚函数用在继承中,当在派生类中需要重新定义基类的函数时需要在基类中将该函数声明为虚函数,作用为使程序支持动态联遍。

3.堆和栈的区别栈(stack):由编译器自动分配释放,存放函数的参数值,局部变量的值等。

其操作方式类似于数据结构中的栈。

堆:一般由程序员分配释放,若不释放,程序结束时可能由OS回收。

注意它与数据结构中的堆是两回事,分配方式类似。

4.头文件的作用是什么?一、通过头文件来调用库功能。

在很多场合,源代码不便(或不准)向用户公布,只要向用户提供头文件和二进制的库即可。

用户只需要按照头文件中的接口声明来调用库功能,而不必关心接口怎么实现的。

编译器会从库中提取出相应的代码。

二、头文件能加强类型安全检查。

如果某个接口被实现或被使用时,其方式与头文件中的声明不一致,编译器就会指出错误,这一简单的规则能大大减轻程序员调试、改错的负担。

5.内存的分配方式有几种?一、从静态存储区域分配。

内存在程序编译的时候已经分配好,这块内存在程序的整个运行期间都存在。

如全局变量。

二、在栈上创建。

在执行函数时,函数内局部变量的存储单元都可以在栈上创建,函数执行结束时这些存储单元自动被释放。

栈内存分配运算内置于处理器的指令集中,效率高,但是分配的内存容量有限。

三、从堆上分配,亦称动态内存分配。

程序在运行的时候用malloc或new申请任意多少的内存,程序员自己负责在何时用free或delete释放内存。

动态内存的生存期由我们决定,使用非常灵活。

6.BOOL、float、指针变量与“零值比较的if语句”。

BOOL:If(flag)或if(!flag)Float:const float EPSINON = 0.00001;If((x>=.EPSINON)&&(x<=EPSINON)) 说明:不可将浮点变量用“==”或“!=”与数字比较,应该设法转化成“>=”或“<=”此类形式。

指针*p:if(p==NULL) if(p!=NULL)7.以下为Windows NT下的32位C++程序,请计算sizeof的值Char str[] = “Hello”;Char *p = str;Int n = 10请计算:Sizeof(str) = 6Sizeof(p) = 4Sizeof(n)=2Void Func(char str[100]){请计算:sizeof(str) = 4}Void *p = malloc(100)请计算:sizeof(p) = 48.#include <>和#include “”有什么区别对于#include <>,编译器从标准库路径开始搜索,对于#include “”,编译器从用户的工作路径中开始搜索9.Const有什么用途1.可以定义const常量2.Const可以修饰函数的参数、返回值,甚至函数的定义体。

被const修饰的东西都受到强制保护,可以预防意外的变动,能提高程序的健壮性。

10.在C++程序中调用被C编译器编译后的函数,为什么要加extern “C”?C++语言支持函数重载,C语言不支持函数重载。

函数被C++编译后在库中的名字与C语言的不同。

假设某个函数的原型为:void fee(int x,inty);该函数被C编译器编译后在库中的名字为_foo,而C++编译器则会产生像_foo_int_int之类的名字。

C++提供了C连接交换指定符号extern “C”来解决名字匹配的问题。

11.内存思考题Void GetMemory(char *p){P = (char *)malloc(100);}Void Test(void){Char *str = NULL;GetMemory(str);Strcpy(str,”hello world”);Printf(str);}请问运行Test函数会有什么样的结果?程序会崩溃,因为GetMemory并不能传递动态内存,Test函数中的str一直是NULL。

Strycpy(str,”hello world”);将使程序崩溃。

Char *GetMemory(void){Char p[] = “hello world”;Return p;}Void Test(void){Char *str = NULL;Str = GetMemory();Printf(str);}请问Test函数会有什么样的结果?可以是乱码。

因为GetMemory返回的是指向“栈内存”的指针,该指针的地址不是NULL,但其原现的内容已经被清除,新内容不知。

Void GetMemory2(char **p,int num){*P = (char *)malloc(num);}Void Test(void){Char *str = NULL;GetMemory(&str,100);Strcpy(str,”hello”);Printf(str);}请问运行Test函数会有什么样的结果?1.能够输出hello2.内存泄露Void Test(void){Char *str = (char *) malloc(100);Strcpy(str,”hello”);Free(str);If(str != NULL){Strcpy((str,”world”);Printf(str);}}请问运行Test函数会有什么样的结果?篡改动态内存区的内容,后果难以预料,非常危险。

因为free(str);之后,str成为野指针,if(str!=NULL)语句不起作用。

12.头文件的作用是什么?一、通过头文件来调用库功能。

在很多场合,源代码不便(不准)向用户公布,只要向用户提供头文件和二进制的库即可。

用户只需要按照头文件中的接口声明来调用库功能,而不必关心接口怎么实现的。

编译器会从库中提取相应的代码。

二、头文件能加强类型安全检查。

如果某个接口被实现或被使用时,其方式与头文件中的声明不一致,编译器就会指出错误,这一简单的规则能减轻程序员调试、改错的负担。

13.C++里面晃是不所有的动作都是main()引起的?如果不是,请举例在运行C++程序时,通常从main()函数开始执行。

因此如果没有main(),程序将不完整,编译器将指出未定义main()函数。

例外情况:如,在windows编程中,可以编写一个动态连接库(DLL)模块,这是其他windows程序可以使用的代码。

由于DLL模块不是独立的程序,因此不需要main()。

用于专用环境的程序――如机器人中的控制器芯片――可能不需要main(),但常规的独立程序都需要main().14.引用与指针的区别:1、引用总是指向某个对象,定义时没有初始化是错误的;2、给引用赋值是修改引用所关联的对象的值,所关联的对象不变。

15.变量的声明和定义有什么区别从编译原理上来说,声明是仅仅告诉编译器,有个某类型的变量会被使用,但是编译器并不会为它分配任何内存。

而定义就是分配了内存。

16.Sizeof和strlen区别1、Sizeof操作符的结果类型是size_t,它在头文件中typedef为unsigned int类型。

该类型保证能容纳实现所建立的最大对象的字节大小。

2、Sizeof是运算符,strlen是函数3、Sizeof可以用类型做参数,strlen只能用char*做参数,且必须是以换行符“\0”结尾的。

4、Strlen的结果要在运行的时候才能计算出来,是用来计算字符串的长度,不是类型占内存的大小。

5、数组做sizeof的参数不退化,传递给strlen就退化为指针;17.C中malloc与new的区别1、new是C++中的操作符,malloc是C中的一个函数;2、new不上是分配内存,而且会调用类的构造函数,同理delete会调用类析构函数,而malloc则只分配内存,不会进行初始化类成员的工作,同样free也不会调用析构函数。

3、内存泄露对于malloc或者new都可以检查出来的,区别在于new可以指明那个文件的那一行,而malloc没有这些信息。

4、New和malloc效率比较New有三个字母,malloc有六个字母New可以认为是malloc加构造函数的执行。

New出来的指针是直接带类型信息。

而malloc返回的都是void指针。

18.关键字static在C和C++中的区别1、在C语言中,主要体现在静态全局变量、静态局部变量和静态函数。

2、在C++中,主要体现在静态数据成员和静态成员函数。

19.简述#define #endif 和#ifndef的作用#define指示接受一个名字并定义该名字为预处理器变量;#ifndef检测指定的预处理变量是否定义;#endif预处理未定义20.实现双向链表删除一个节点P,在节点P后插入一个节点,写出这两个函数;答:双向链表删除一个节点PTemplate<class type> void list<type>::delnode(int p){int k = 1;listnode<type> *ptr,*t;ptr = first;While(ptr->next!=NULL&&k!=p){ptr = ptr->next;k++;}t = ptr->next;cout <<”你已经将数据项”<<t->data<<”删除”<<endl;ptr->next = ptr->next->next;length--;delte t;}在节点P后插入一个节点:Template<class type> bool list<type>::insert(type t,int p){Listnode<type> *ptr;Ptr = first;int k = 1;while(ptr != NULL && k < p){ptr = ptr->next;k++;}If(ptr == NULL && k!=p){return false;}else{Listnode<type> *tp;tp = new listnode<type>;tp->data = t;tp->next = ptr->next;ptr->next = tp;length++;return true;}}21.sizeof的使用场合sizeof操作符一个主要用途是存储分配和I/O系统那样的例程进行通信。

相关文档
最新文档