C++简答题和编程题汇总-题库
- 格式:doc
- 大小:68.50 KB
- 文档页数:11
C++ 简答题和编程题汇总一、简答题:1.有以下程序结构,请分析访问属性。
class CA{public:void fun1( );int i;protected:void fun2( );int j;private:int k;};class CB: protected CA{public:void fun3( );protected:int m;private:int n;};class CC: public CB{public:void fun4( );private:int p;};int main( ){CA a;CB b;CC c1;return 0;}问: ( 1 )派生类CB中的成员函数能否引用基类CA中的数据成员i,j,k?( 2 )派生类CC中的成员函数能否调用基类CA中的成员函数fun1和fun2?(3)能否在main函数中用 c.fun1(),c.fun2(),c.fun3()和 c.fun4()调用fun1,fun2,fun3,fun4成员函数?答:(1)可以用b1.i引用对象b中的基类A的成员i,因为它是公用数据成员。
不能用b1.j引用对象b中的基类A的成员j,因为它是保护数据成员,在类外不能访问。
不能用b1.k引用对象b中的基类A的成员k,因为它是私有数据成员,在类外不能访问。
(2)可以引用基类A中的数据成员i,j,因为它们在派生类中是公用成员和保护成员,可以被派生类的成员函数访问。
不可以引用基类A中的数据成员k,它在派生类中是不可访问的成员。
(3)可以调用成员函数f1,f3,f4,它们是公用成员函数。
不能调用成员函数f2,因为它是保护成员函数。
2.为什么要使用虚基类?怎样定义虚基类?用一个实例来解释虚基类在其派生类中的存储方式。
答:如果一个派生类有多个直接基类,而这些直接基类又有一个共同的基类,则在最终的派生类中会保留该间接共同基类数据成员的多份同名成员。
如图所示:(a)派生关系(b)存储图存储关系如(b),在职研究生类有两个Person拷贝。
期末c语言考试题库及答案一、选择题(每题2分,共20分)1. C语言中,以下哪个关键字用于定义一个结构体?A. structB. unionC. enumD. typedef答案:A2. 下列哪个选项是合法的C语言变量名?A. 2nd_variableB. _variableC. variable-nameD. variable$name答案:C3. 在C语言中,以下哪个函数用于将字符串转换为浮点数?A. atoiB. atofC. itoaD. sprintf答案:B4. 下列哪个选项是C语言中的逻辑运算符?A. &&B. ||C. ==D. =答案:A5. C语言中,以下哪个关键字用于定义一个函数?A. classB. functionC. intD. void答案:C6. 在C语言中,以下哪个选项表示“不等于”?A. ==B. !=C. =D. <=答案:B7. 下列哪个选项是C语言中的循环结构?A. ifB. forC. switchD. case答案:B8. 在C语言中,以下哪个函数用于计算字符串的长度?A. strlenB. strcpyC. strcatD. strcmp答案:A9. C语言中,以下哪个关键字用于定义一个指针?A. *B. &C. %D. #答案:A10. 下列哪个选项是C语言中的数组?A. int a[10];B. int *a;C. int a=10;D. int a;答案:A二、填空题(每题2分,共10分)1. 在C语言中,用于定义一个字符常量的数据类型是______。
答案:char2. 在C语言中,用于定义一个整型变量的数据类型是______。
答案:int3. 在C语言中,用于定义一个浮点型变量的数据类型是______。
答案:float4. 在C语言中,用于定义一个双精度浮点型变量的数据类型是______。
答案:double5. 在C语言中,用于定义一个布尔型变量的数据类型是______。
c语言期末考试题库大题及详解答案C语言期末考试题库大题及详解答案一、简答题1. 请简述C语言的基本数据类型及其特点。
答案:C语言的基本数据类型包括整型(int)、浮点型(float和double)、字符型(char)和枚举型(enum)。
整型用于存储整数,浮点型用于存储小数,字符型用于存储单个字符,枚举型用于定义一组命名的常量。
每种数据类型都有其特定的取值范围和占用内存大小。
2. 请解释C语言中的数组和指针的区别。
答案:数组是一种数据结构,用于存储固定数量的相同类型元素,可以通过下标访问元素。
指针是一个变量,它存储另一个变量的内存地址。
数组名可以作为指向数组第一个元素的指针使用,但数组本身是一个固定大小的内存块,而指针可以被赋值为不同的地址,具有动态性。
二、编程题1. 编写一个C语言程序,实现输入三个整数,找出其中的最大值并输出。
答案:```c#include <stdio.h>int main() {int num1, num2, num3, max;printf("请输入三个整数:");scanf("%d %d %d", &num1, &num2, &num3);max = (num1 > num2) ? ((num1 > num3) ? num1 : num3) : ((num2 > num3) ? num2 : num3);printf("最大值是:%d\n", max);return 0;}```2. 编写一个C语言程序,实现字符串的反转。
答案:```c#include <stdio.h>#include <string.h>int main() {char str[100];printf("请输入一个字符串:");fgets(str, sizeof(str), stdin); // 使用fgets以包含空格int len = strlen(str) - 1; // 减去换行符长度for (int i = len; i >= 0; --i) {printf("%c", str[i]);}printf("\n");return 0;}```三、综合题1. 请编写一个C语言程序,实现一个简单的计算器,能够进行加、减、乘、除四种基本运算。
C语言的简答题包含解答共50道题1. 什么是C语言?- C语言是一种通用的高级编程语言,由Dennis Ritchie于1972年开发。
它被广泛用于系统编程和应用程序开发。
2. C语言的主要特点是什么?- C语言具有简洁的语法、高效的性能、直接的硬件访问能力和强大的标准库。
3. 什么是C标准库?-C标准库包含了一组标准的C语言函数,用于执行常见任务,如输入/输出、字符串操作、数学运算等。
4. 如何声明一个变量?-变量的声明通常以数据类型开始,例如:`int myVariable;`5. C语言中有多少个基本数据类型?- C语言有四个基本数据类型,分别是整数、字符、浮点数和指针。
6. 什么是常量?-常量是在程序中固定不变的值,可以用于存储数据或作为计算中的固定值。
7. 如何定义常量?-使用`const`关键字定义常量,例如:`const int myConstant = 10;`8. 什么是变量的作用域?-变量的作用域指的是变量在程序中可见的区域,它可以是全局作用域或局部作用域。
9. 什么是数据类型转换?-数据类型转换是将一个数据类型的值转换为另一个数据类型的过程,通常使用类型转换运算符进行。
10. 什么是条件语句?-条件语句是根据条件执行不同的代码块的语句,通常使用`if`、`else if`和`else`关键字实现。
11. 什么是循环语句?-循环语句用于重复执行一组语句,通常使用`for`、`while`和`do-while`循环。
12. 什么是数组?-数组是一组相同数据类型的元素的集合,通过索引访问。
13. 如何声明和初始化数组?-数组的声明和初始化可以在一行中完成,例如:`int myArray[5] = {1, 2, 3, 4, 5};`14. 什么是字符串?-字符串是字符的序列,通常用于表示文本数据。
15. 如何声明和初始化字符串?-使用字符数组来声明和初始化字符串,例如:`char myString[] = "Hello";`16. 什么是指针?-指针是一个变量,存储了一个内存地址,可以用于访问该地址处的数据。
c语言考试题及答案一、选择题(每题2分,共20分)1. 下列关于C语言的描述中,错误的是:A. C语言是一种高级语言B. C语言可以直接被计算机执行C. C语言具有结构化的特点D. C语言具有跨平台的特性答案:B2. C语言中,用于定义一个整型变量的关键字是:A. intB. floatC. doubleD. char答案:A3. 在C语言中,以下哪个运算符用于取模运算?A. %B. /C. *D. -答案:A4. 下列关于数组的描述中,正确的是:A. 数组必须在程序开始时初始化B. 数组的元素可以是不同的数据类型C. 数组的索引从1开始D. 数组的声明必须指定数组的大小答案:D5. 在C语言中,以下哪个关键字用于定义一个函数?A. intB. voidC. functionD. define答案:B6. C语言中,用于表示逻辑“与”操作的运算符是:A. &&B. ||C. !D. &答案:A7. 下列哪个选项是C语言中合法的注释?A. // 这是一个注释B. /* 这是一个注释 */C. // 这是一个注释/* 这是一个注释 */D. /* 这是一个注释 */答案:A8. C语言中,用于定义一个空指针的值是:A. NULLB. 0C. falseD. none答案:A9. 下列关于指针的描述中,错误的是:A. 指针可以存储变量的地址B. 指针可以存储函数的地址C. 指针可以存储数组的索引D. 指针可以存储指针的地址答案:C10. 在C语言中,用于定义一个字符型指针的声明是:A. char *ptr;B. int *ptr;C. float *ptr;D. double *ptr;答案:A二、填空题(每题2分,共20分)1. 在C语言中,定义一个整型数组的语法是:______ int array[10];。
答案:int2. 如果一个变量的值是10,那么表达式sizeof(&var)的结果是:______。
大学c语言试题题库及答案一、选择题(每题2分,共20分)1. 下列关于C语言的描述,正确的是:A. C语言是一种编译型语言B. C语言是一种解释型语言C. C语言是一种面向对象的语言D. C语言不支持函数答案:A2. 在C语言中,用于定义一个整型变量的关键字是:A. intB. floatC. charD. double答案:A3. 下列哪个选项是C语言中的合法标识符?A. 2variableB. variable2C. intD. _int答案:B4. C语言中,用于定义一个浮点型数组的语法是:A. int array[10];B. float array[10];C. char array[10];D. double array[10];答案:B5. 在C语言中,哪个运算符用于取模运算?A. %B. /C. *D. +答案:A6. 下列哪个选项是C语言中的逻辑运算符?A. &&B. ||C. ==D. =答案:A7. 在C语言中,用于定义一个字符型数组的语法是:A. int array[10];B. float array[10];C. char array[10];D. double array[10];答案:C8. C语言中,用于声明一个函数的关键字是:A. intB. floatC. voidD. return答案:C9. 下列哪个选项是C语言中的循环结构?A. ifB. switchC. forD. while答案:C10. 在C语言中,用于定义一个字符串常量的语法是:A. "Hello"B. 'Hello'C. "Hello"[10]D. 'Hello'[10]答案:A二、填空题(每题2分,共20分)1. 在C语言中,使用________运算符可以连接两个字符串。
答案:+2. C语言中的________关键字用于声明一个无返回值的函数。
C语言的简答题包含解答共60道题1. 什么是C语言?◆C语言是一种通用的编程语言,由Dennis Ritchie于1972年开发。
它被广泛用于系统编程、应用程序开发和嵌入式系统等领域。
2. 什么是C语言的注释?◆在C语言中,注释用于添加对代码的解释和说明。
有两种类型的注释:单行注释(//)和多行注释(/* */)。
3. 什么是变量?如何声明变量?◆变量是用于存储数据的标识符。
在C语言中,变量的声明包括变量类型和名称,例如:`int myVariable;`。
4. 什么是数据类型?举例说明几种C语言的数据类型。
◆数据类型定义了变量可以存储的数据类型。
一些C语言的数据类型包括int、float、char、double等。
5. 什么是C语言的关键字?◆关键字是C语言中具有特殊含义的保留字,不能用作变量名。
例如,`if`、`while`、`for`等是关键字。
6. 什么是运算符?举例说明一些C语言的运算符。
◆运算符用于执行各种数学和逻辑操作。
例如,+、-、*、/是算术运算符,==、!=、>、<是比较运算符。
7. 什么是条件语句?举例说明一个C语言的条件语句。
◆条件语句用于根据条件执行不同的代码块。
例如,`if`语句用于在条件满足时执行特定的代码块。
8. 什么是循环语句?举例说明一个C语言的循环语句。
◆循环语句用于多次执行相同的代码块。
例如,`for`循环用于按照特定条件重复执行代码块。
9. 什么是函数?如何声明和定义一个函数?◆函数是可重复使用的代码块,用于执行特定任务。
函数的声明包括函数返回类型、名称和参数列表,例如:`int add(int a, int b);`。
10. 什么是指针?如何声明和使用指针?◆指针是用于存储变量地址的变量。
指针的声明包括指针类型和名称,例如:`int *ptr;`。
要使用指针,可以使用`&`运算符获取变量的地址,使用`*`运算符访问指针指向的值。
11. 什么是C语言中的数组?◆数组是一种用于存储相同数据类型的元素集合的数据结构。
c语言程序设计试题及答案C语言程序设计试题及答案一、选择题(每题2分,共20分)1. C语言中,以下哪个是合法的变量名?A. 2variableB. variable-nameC. variable_nameD. variable-2答案:C2. 以下哪个语句不是C语言中的输入语句?A. scanf("%d", &x);B. printf("%d", x);C. gets("string");D. getchar();答案:B3. C语言中,以下哪个不是标准库函数?A. printf()B. malloc()C. strcpy()D. main()答案:D4. 以下哪个选项是C语言中正确的数组声明?A. int array[];B. int [10] array;C. int array[10];D. int [10] = array;答案:C5. 以下哪个是C语言中正确的字符串字面量?A. "Hello World"B. 'Hello World'C. "Hello\nWorld"D. "Hello World"答案:C6. C语言中,以下哪个是正确的函数声明?A. int function();B. void myFunction(int x, int y);C. int myFunction(int x, int y) {}D. int myFunction(int x, int y) { return x + y; }答案:B7. 在C语言中,以下哪个是正确的条件语句?A. if (x = 5)B. if (x == 5)C. if (x = 5) { x++; }D. if (x == 5) { x++; }答案:D8. 在C语言中,以下哪个是正确的循环语句?A. for (int i = 0; i <= 10; i++) {}B. for (int i = 0; i < 10; i--) {}C. while (x != 0) { x--; }D. do { x++; } while (x != 0);答案:D9. 在C语言中,以下哪个是正确的指针声明?A. int *ptr;B. *int ptr;C. int ptr*;D. int * ptr;答案:A10. C语言中,以下哪个不是运算符?A. +B. -C. :D. *答案:C二、简答题(每题5分,共30分)1. 请简述C语言中数组和指针的区别。
全国计算机c语言试题及答案一、选择题1. 下列哪个选项不是C语言的基本数据类型?- A. int- B. float- C. string- D. double2. 以下哪个是正确的C语言变量声明?- A. var int a;- B. int a = 0;- C. int a = 0.0;- D. int a = '0';3. 在C语言中,以下哪个是合法的数组初始化?- A. int arr[5] = {1, 2, 3};- B. int arr[5] = {1, 2, 3, 4};- C. int arr[5] = {1, 2, 3, 4, 5, 6};- D. int arr[5] = {1, 2, 3, 4.5, 5};4. 以下哪个是C语言中的函数原型?- A. void myFunction();- B. myFunction();- C. int myFunction(int, int);- D. myFunction(int a, int b);5. 在C语言中,以下哪个是正确的字符串常量?- A. "Hello World"- B. 'Hello World'- C. "Hello\nWorld"- D. "Hello\World"二、填空题1. 在C语言中,一个变量的声明必须在______。
2. 一个C语言程序的执行从______函数开始。
3. 用于输入输出的函数分别是______和______。
4. 一个数组的元素可以通过______访问。
5. 在C语言中,一个字符串常量以______结尾。
三、简答题1. 解释C语言中指针的概念及其用途。
2. 描述C语言中函数的作用域。
3. 简述C语言中结构体的定义和使用。
四、编程题1. 编写一个C语言程序,计算并输出1到100的整数和。
2. 编写一个C语言函数,实现字符串的反转。
计算机系c语言考试题及答案C语言作为计算机科学与技术专业中的重要课程之一,考试是检验学生对于C语言基本知识和编程能力的重要方式之一。
下面将为大家提供一套C语言的考试题目及其答案,帮助大家更好地复习和准备考试。
题目一:简答题(20分)1. C语言中的运算符有哪些?请分别举例并说明其功能。
2. 什么是指针?请简要描述指针的概念和用途。
3. C语言中的控制结构有哪些?请简要说明各种控制结构的特点和应用场景。
(参考答案)1. C语言中常见的运算符包括算术运算符(+、-、*、/)、关系运算符(>、<、==、!=)、逻辑运算符(&&、||、!)、位运算符(&、|、^、~)、赋值运算符(=)、条件运算符(? :)等。
例如:算术运算符可以用于对变量进行加减乘除等操作,如 a + b、c - d;关系运算符用于比较两个变量的大小关系,如a > b;逻辑运算符用于进行逻辑判断,如 a > b && c < d;位运算符用于对二进制位进行位操作,如 a & b。
2. 指针是C语言中的一种特殊数据类型,用于存储变量的内存地址。
可以通过指针来间接访问或修改对应内存地址中的数据。
指针在C语言中具有重要作用,可用于动态分配内存、传递参数、实现数据结构等。
例如,int *p; 声明了一个整型指针变量p,可以用来存储整型变量的地址。
3. C语言中的控制结构包括顺序结构、分支结构(if-else语句、switch-case语句)和循环结构(for循环、while循环、do-while循环等)。
顺序结构按照代码的先后顺序依次执行;分支结构根据条件的判断结果选择执行不同的代码段;循环结构根据条件的判断结果重复执行一段代码。
这些控制结构在程序设计中用于控制程序的流程和逻辑。
题目二:编程题(30分)实现一个简单的学生成绩管理系统,要求能够输入学生信息(包括姓名、学号、各科成绩等),并能够计算并显示学生的平均成绩和总成绩。
C++ 简答题和编程题汇总一、简答题:1.有以下程序结构,请分析访问属性。
class CA{public:void fun1( );int i;protected:void fun2( );int j;private:int k;};class CB: protected CA{public:void fun3( );protected:int m;private:int n;};class CC: public CB{public:void fun4( );private:int p;};int main( ){CA a;CB b;CC c1;return 0;}问: ( 1 )派生类CB中的成员函数能否引用基类CA中的数据成员i,j,k?( 2 )派生类CC中的成员函数能否调用基类CA中的成员函数fun1和fun2?(3)能否在main函数中用 c.fun1(),c.fun2(),c.fun3()和 c.fun4()调用fun1,fun2,fun3,fun4成员函数?答:(1)可以用b1.i引用对象b中的基类A的成员i,因为它是公用数据成员。
不能用b1.j引用对象b中的基类A的成员j,因为它是保护数据成员,在类外不能访问。
不能用b1.k引用对象b中的基类A的成员k,因为它是私有数据成员,在类外不能访问。
(2)可以引用基类A中的数据成员i,j,因为它们在派生类中是公用成员和保护成员,可以被派生类的成员函数访问。
不可以引用基类A中的数据成员k,它在派生类中是不可访问的成员。
(3)可以调用成员函数f1,f3,f4,它们是公用成员函数。
不能调用成员函数f2,因为它是保护成员函数。
2.为什么要使用虚基类?怎样定义虚基类?用一个实例来解释虚基类在其派生类中的存储方式。
答:如果一个派生类有多个直接基类,而这些直接基类又有一个共同的基类,则在最终的派生类中会保留该间接共同基类数据成员的多份同名成员。
如图所示:(a)派生关系(b)存储图存储关系如(b),在职研究生类有两个Person拷贝。
为避免这种情况,可使用虚基类。
虚基类(virtual base class)定义方式如下:class 派生类名:virtual 继承方式基类类名{...};virtual 关键字只对紧随其后的基类名起作用。
采用虚基类后存储关系如下:采用虚基类后在职研究生类储存图3.请比较函数重载和虚函数在概念和使用方式方面有什么区别?答:(1)函数重载可以用于普通函数(非成员函数)和成员函数,而虚函数只能用于类的成员函数;(2)函数重载可以用于构造函数,而虚函数不能用于构造函数;(3)如果对成员函数进行重载,则重载的函数与被重载的函数应当都是同一个类的成员函数,不能分属于两个不同继承层次的类。
虚函数是对同一类族中基类和派生类的同名函数的处理,即允许在派生类中对基类的成员函数重新定义。
(4)重载的函数必须具有相同的函数名,但函数参数个数和参数类型二者中至少有一样不同。
而虚函数则要求在同一族中的所有虚函数不仅函数名相同,而且要求函数类型、函数参数个数和参数类型都全部相同。
(5)重载的函数是在程序编译阶段确定操作对象的,属静态关联。
虚函数是在程序运行阶段确定操作的对象的,属动态关联。
4.派生类的析构函数中需完成什么任务?是否要编写对基数和成员对象的析构函数的调用?为什么?答:析构函数的功能是在对象被系统释放之前做必要的“清理现场”的工作,析构函数无返回类型也没有参数,情况比较简单。
派生类析构函数定义格式与非派生类无任何差异,不要编写对基数和成员对象的析构函数的调用,只要在函数体内把派生类新增一般成员处理好就可以了,因为对新增的成员对象和基类的善后工作,系统会自己调用成员对象和基类的析构函数来完成。
5.简单叙述派生类与基类的赋值兼容规则。
答:凡是基类所能解决的问题,公有派生类都可以解决。
在任何需要基类对象的地方都可以用公有派生类的对象来代替,这条规则称赋值兼容规则。
它包括以下情况:(1)派生类的对象可以赋值给基类的对象,这时是把派生类对象中从对应基类中继承来的成员赋值给基类对象。
反过来不行,因为派生类的新成员无值可赋。
(2)可以将一个派生类的对象的地址赋给其基类的指针变量,但只能通过这个指针访问派生类中由基类继承来的成员,不能访问派生类中的新成员。
同样也不能反过来做。
(3)派生类对象可以初始化基类的引用。
引用是别名,但这个别名只能包含派生类对象中的由基类继承来的成员。
6.为什么析构函数总是要求说明为虚函数?答:在基类中及其派生类中都动态分配内存空间时,必须把析构函数定义为虚函数,实现撤消对象时的多态性。
根据赋值兼容规则可以用基类的指针指向派生类对象,如果由该指针撤销派生类对象,则必须将析构函数说明为虚函数,实现多态性,自动调用派生类析构函数。
我们总是要求将类设计成通用的,无论其他程序员怎样调用都必须保证不出错,所以必须把析构函数定义为虚函数。
二、编程题1.(类的声明和运算符重载)设计一个日期类Date,要求:(1)可以建立具有指定日期(年、月、日)的Date对象,默认日期是2007.1.1。
(2)可以从输出流输出一个格式为“年-月-日”的日期,其中年是四位数据,月、日可以是一位也可以是两位数据。
(3)可以动态地设置年、月、日。
(4)可以用运算符= =对两个日期进行是否相等的比较。
(5)在主函数中进行该类的测试。
2.编写一个程序,涉及一个类score用于统计一个班的学生成绩,其中使用一个静态数据成员sumfenshu存储总分和一个静态成员函数Getsumfenshu()返回该总分。
3.用类模板方式设计一个栈类Stack<T>,其中有两个私有数据成员s[](存放栈元素)和top(栈顶元素下标),以及三个公有成员函数push(元素入栈)、pop (元素出栈)和stackempty(判断栈是否为空),并建立一个整数栈和一个字符栈。
4.(类的声明和友元函数)设计一个程序,其中有三个类CBank、BBank、GBank,分别为中国银行类、工商银行类和农业银行类。
每个类都包含一个私有数据balance用于存放储户在该行的存款数,另有一个友元函数max用于显示三家编程题2的类结构5.(类的继承和类的组合)实现两个类person类和scores类,其中person类中包含了公有的个人基本信息,如姓名、性别和年龄等。
scores类包含了公有的考试科目成员如语文、数学、英语等的成绩。
现要求实现一个student类,它继承自person类,并加入了私有的一个表示学号的新成员number和一个scores成员对象。
要求:(1)student类中的个人基本信息和成绩单的访问属性为私有;(2)重载的student构造函数能接受person对象和score对象作为参数,也能接受直接给出的个人基本信息和成绩信息作为参数。
(3)student类提供设置和访问个人信息和成绩的接口函数。
6.(虚函数)已知一个抽象基类person,其结构如下:class person{ public:virtual void info()=0;}要求在person类的基础上派生一个student类和一个teacher类,并实现虚函数info(),它打印出学生和教师的个人信息。
其中,学生的个人信息包括学号、姓名、年龄、性别和系别;教师的个人信息包括工号、姓名、年龄、性别和职称。
另外,实现全局函数print(person*),它接受一个person类型的指针作为参数,调用person的info()函数,打印出person的个人信息。
实例化student和teacher对象,对象的个人信息在定义对象时给定,用print()函数打印出他们的个人信息。
7.下列shape类是一个表示形状的抽象类,area( )为求图形面积的函数,total( )则是一个通用的用以求不同形状的图形面积总和的函数。
请从shape类派生三角形类(triangle)、矩形类(rectangle),并给出具体的求面积函数。
#include <iostream>using namespace std;class shape{public:virtual double area() const=0;};double total(shape *s[],int n){double sum=0.0;for(int i=0;i<n;i++)sum+=s[i]->area();return sum;}class Triangle:public shape{public:Triangle(double h,double w){H=h;W=w;}double area() const{return H*W*0.5;}private:double H,W;};class Rectangle:public shape{public:Rectangle(double h,double w){H=h;W=w;}double area()const{return H*W;}private:double H,W;};int main(){Triangle triangle1(4.0,3.3);Rectangle rectangle1(5.0,4.0);shape *arr[2]={&triangle1,&rectangle1};double sum_area=total(arr,2);cout<<"total area="<<sum_area<<endl;return 0; }8.编写程序,需要求3个长方柱的体积,请编写一个基于对象的程序。
数据成员包括length(长)、width(宽)、 height(高)。
要求用成员函数实现以下功能:(1) 定义构造函数完成长方柱的初始化;(2) 计算长方柱的体积;(3) 输出长方柱的体积。
#include <iostream>using namespace std;class Box{public:Box(float l,float w,float h):length(l),width(w),height(h){}float volume();void display();public:float length;float width;float height;};float Box::volume(){ return(length*width*height);}void Box::display(){ cout<<volume()<<endl;}int main(){Box box1(3,2,1),box2(4,3,2),box3(5,4,3);cout<<"volmue of box1 is ";box1.display();cout<<"volmue of box2 is ";box2.display();cout<<"volmue of box3 is ";box3.display();return 0;}9.设计一个函数模板求一个数组中最大的元素,并以整数数组和字符数组进行调试。