当前位置:文档之家› C++程序设计练习题及答案第七章继承

C++程序设计练习题及答案第七章继承

C++程序设计练习题及答案第七章继承
C++程序设计练习题及答案第七章继承

第7章继承

7.1 选择题

1.在c++中,类与类之间的继承关系具有( c )。

(a) 自反性 (b) 对称性 (c) 传递性 (d) 反对称性

2.下列关于类的继承描述中,( a,b )是错误的。

(a) 派生类可以访问基类的所有数据成员,调用基类的所有成员函数

(b) 派生类也是基类,所以基类具有派生类的全部属性和方法

(c) 继承描述类的层次关系,派生类可以具有与基类相同的属性和方法

(d) 一个基类可以有多个派生类,一个派生类可以有多个基类

3.当一个派生类公有继承一个基类时,基类中的所有公有成员成为派生类的( a )。

(a) public 成员 (b)private成员

(c) protected成员 (d)友员

4.当一个派生类私有继承一个基类时,基类中的所有公有成员和保护成员成为派生类的( b )。

(a) public 成员 (b)private成员

(c) protected成员 (d)友员

5.当一个派生类保护继承一个基类时,基类中的所有公有成员和保护成员成为派生类的( c )。

(a) public 成员 (b)private成员

(c) protected成员 (d)友员

6.不论派生类以何种方式继承基类,都不能使用基类的( b )。

(a) public 成员 (b)private成员

(c) protected成员 (d)public 成员和protected成员

7.下面描述中,错误的是( b, c )。

(a) 在基类定义的public成员在公有继承的派生类中可见,也能在类外被访问

(b) 在基类定义的public和protected成员在私有继承的派生类中可见,在类外可以被访问

(c) 在基类定义的public和protected成员在保护继承的派生类中不可见

(d) 在派生类中不可见的成员要变成可访问的需进行访问声明

8.在c++中,不能被派生类继承的函数是( b,c )。

(a) 成员函数 (b)构造函数

(c) 析构函数 (d)静态成员函数

9.在创建派生类对象时,构造函数的执行顺序是( d )。

(a) 对象成员构造函数、基类构造函数、派生类本身的构造函数

(b) 派生类本身的构造函数、基类构造函数、对象成员构造函数

(c) 基类构造函数、派生类本身的构造函数、对象成员构造函数

(d) 基类构造函数、对象成员构造函数、派生类本身的构造函数10.当不同的类具有相同的间接基类时,有特点( d )。

(a) 各派生类对象将按继承路线产生自己的基类版本

(b) 派生类对象无法产生自己的基类版本

(c) 为了建立惟一的间接基类版本,应该必须改变类格

(d) 为了建立惟一的间接基类版本,应该声明虚继承

7.2 阅读下列程序,写出执行结果

1.#include

class BASE

{ public:

void get( int i,int j,int k,int l )

{ a = i; b = j; x = k; y = l; }

void print()

{ cout << "a = "<< a << '\t' << "b = " << b << '\t'

<< "x = " << x << '\t' << "y = " << y << endl;

}

int a,b;

protected:

int x, y;

};

class A: public BASE

{ public:

void get( int i, int j, int k, int l )

{ BASE obj3;

obj3.get( 50, 60, 70, 80 );

obj3.print();

a = i;

b = j; x = k; y = l;

u = a + b + obj3.a ; v = y - x + obj3.b;

}

void print()

{ cout << "a = " << a << '\t' << "b = " << b << '\t'

<< "x = " << x << '\t' << "y = " << y << endl;

cout << "u = " << u << '\t' << "v = " << v << endl;

}

private:

int u, v ;

};

void main()

{ BASE obj1;

A obj2;

obj1.get( 10, 20, 30, 40 );

obj2.get( 30, 40, 50, 60 );

obj1.print();

obj2.print();

}

答案:

a = 50

b = 60 x = 70 y = 80

a = 10

b = 20 x = 30 y = 40

a = 30

b = 40 x = 50 y = 60

u = 120 v = 70

2. #include

class BASE1

{ public:

BASE1( int i ) { cout << "调用基类BASE1的构造函数:" << i << endl ; }

};

class BASE2

{ public:

BASE2( int j ) { cout << "调用基类BASE2的构造函数:" << j << endl ; }

};

class A: public BASE1, public BASE2

{ public:

A( int a, int b, int c, int d ) : BASE2(b), BASE1(c), b2(a), b1(d) { cout << "调用派生类A的构造函数:" << a+b+c+d << endl; } private:

BASE1 b1;

BASE2 b2;

} ;

void main()

{ A obj( 1, 2, 3, 4 ); }

答案:

调用基类BASE1的构造函数:3

调用基类BASE2的构造函数:2

调用基类BASE1的构造函数:4

调用基类BASE2的构造函数:1

调用派生类A的构造函数:10

7.3 编程题

1.定义一个rectangle类,它包含两个数据成员length和width;以及包含用于求长方形面积的成员函数。再定义rectangle的派生类rectangular,它包含一个新数据成员height和用来求长方体体积的成员函数。在main函数中,使用两个类,求某个长方形的面积和某个长方体的体积。

解答:

#include

class rectangle

{

public:

rectangle( float l,float w )

{ length = l;width = w; }

float area()

{ return( length*width ); }

float getlength() { return length; }

float getwidth() { return width; }

private:

float length;

float width;

};

class rectangular:public rectangle

{ public:

rectangular( float l,float w,float h ) : rectangle( l,w )

{ height = h; }

float getheight() { return height; }

float volume() { return area() *height; }

private:

float height;

};

void main()

{ rectangle obj1( 2,8 );

rectangular obj2( 3,4,5 );

cout << "length=" << obj1.getlength() << '\t' << "width=" << obj1.getwidth() << endl;

cout << "rectanglearea=" << obj1.area() << endl;

cout << "length=" << obj2.getlength() << '\t' << "width=" << obj2.getwidth();

cout << '\t'<< "height=" << obj2.getheight() << endl;

cout << "rectangularvolume=" << obj2.volume() << endl;

}

2. 假设某销售公司有销售经理和销售员工,月工资的计算办法是:销售经理的固定月薪为8000元并提取销售额的千分之五作为工资;销售员工只提取销售额的千分之五作为工资。编一程序,定义一个基类employee,它包含三个数据成员number、name和salary,以及用于输入编号和姓名的构造函数。由employee类派生salesman类,再由salesman类派生salesmanager类。salesman类包含两个新数据成员 commrate和sales,还包含用于输入销售额并计算销售员工工资的成员函数pay()和用于输出的成员函数print()。salesmanager类包含新数据成员 monthlypay,及用于输入销售额并计算销售经理工资的成员函数pay()、用于输出的成员函数print()。在main函数中,测试你的类结构,求若干个不同员工的工资。

解答:略。

3.试写出所能想到的所有形状(包括二维的和三维的),生成一个形状层次类结构。生成的层次结构以Shape作为基类,并由此派生出TwoDimShape 类和ThreeDimShape类。它们的派生类是不同形状类。定义层次结构中的每一个类,并用main函数进行测试。

解答:略

C语言程序设计第四版第七章答案 谭浩强

第七章函数 7.1写两个函数,分别求两个整数的最大公约数和最小公倍数,用主函数调用这两个函数,并输出结果两个整数由键盘输入。 maxyueshu(m,n) int m,n; { int i=1,t; for(;i<=m&&i<=n;i++) {if(m%i==0&&n%i==0) t=i; } return(t); } minbeishu(m,n) int m,n; {int j; if(m>=n) j=m; else j=n; for(;!(j%m==0&&j%n==0);j++); return j; } main() {int a,b,max,min; printf("enter two number is: "); scanf("%d,%d",&a,&b); max=maxyueshu(a,b); min=minbeishu(a,b); printf("max=%d,min=%d\n",max,min); } 7.2求方程的根,用三个函数分别求当b2-4ac大于0、等于0、和小于0时的根,并输出结果。从主函数输入a、b、c的值。 #include"math.h" float yishigen(m,n,k) float m,n,k; {float x1,x2; x1=(-n+sqrt(k))/(2*m); x2=(-n-sqrt(k))/(2*m); printf("two shigen is x1=%.3f and x2=%.3f\n",x1,x2); } float denggen(m,n) float m,n; {float x; x=-n/(2*m); printf("denggen is x=%.3f\n",x); }

C语言程序设计第三版习题库答案

C 语言程序设计(第三版)习题库 1、设圆半径r=,圆柱高h=3,求圆周长、圆面积、圆球表面积、圆球体积、圆柱体积。用scanf 输入数据,输出计算结果,输出时要求文字说明,取小数点后两位数字。请编程序。 #include<> main(){ floatr,h,C1,Sa,Sb,Va,Vb; scanf(__”%f ”__,&r); scanf(”%d ”,__&h _);; C1=2**r; Sa=*r*r; Sb=4*Sa; Va=4**r*r*r/3; Vb=Sa*h; printf(___”Cl=%.2fSa=%.2fSb=%.2fVa=%.2fVb=%.2f ”,Cl,Sa,Sb,Va,Vb ); } 2、输入一个华氏温度,要求输出摄氏温度。公式为c=5(F-32)/9 输出要求有文字说明,取位2小数。 #include<> main(){ floatF,c; scanf("%f",&F); ____c=5*(F-32)/9______; printf("c=%.2f",c); } 3、有一函数:?? ???≥-<≤-<=10113101121x x x x x x y 写一程序,输入x 值,输出y 值。 #include<> main(){ intx,y; printf("输入x :"); scanf("%d",&x); if(x<1){/*x<1*/ y=x; printf("x=%3d,y=x=%d\n",x,y);

}elseif(____x<10_______){/*1≤x-10*/ _____y=2*x-1_______; printf("x=%3d,y=2*x-1=%d\n",x,y); }else{/*x≥10*/ y=3*x-11; printf("x=%3d,y=3*x-11=%d\n",x#include"" main() { intx,y; scanf("%d",&x); if(x<1) {y=x;} elseif(x>=1&&x<10) {y=2*x-1;} else {y=3*x-11;} printf("%d",y); }#include"" main() { intx,y; scanf("%d",&x); if(x<1) {y=x;} elseif(x>=1&&x<10) {y=2*x-1;} else {y=3*x-11;} printf("%d\n",y); }#include"" main() { intx,y; scanf("%d",&x); if(x<1) {y=x;} elseif(x>=1&&x<10) {y=2*x-1;} else {y=3*x-11;} printf("%d",y); }scanf("%d",&x);

电力系统思考题答案

第一章电力系统的基本概念 1、何谓电力系统、电力网? 电力系统——是由发电机(发电厂)、变压器(变电站)、电力线路及用户组成的。 电力网络——是由变压器、电力线路等变换、输送、分配电能设备所组成的部分。 动力系统——在电力系统的基础上,把发电厂的动力部分(例如火力发电厂的锅炉、汽轮机和水力发电厂的水库、水 轮机以及核动力发电厂的反应堆等)包含在内的系统。 2、电力系统运行有什么特点及要求? 特点:1 电能不能大量储存2 暂态过程非常短促2 与国民经济及日常生活关系密切。要求:1 保证安全可靠的供电(安 全)2 保证良好的电能质量(优质)3 良好的经济性(经济)4 提供充足的电能(充足)5 环保问题(环保) 3、我国目前3KV 及以上的电压等级是什么? 我国规定的电力系统额定电压等级(KV):3、6、10、35、(60)、110、(154)、220、330、500KV 4、电力系统各元件的额定电压是如何确定的? 1 用电设备的额定电压与系统的额定电压相同 2 线路的额定电压:线路额定电压即线路的平均电压(Ua+Ub)/2 。线路两端都可以接用电设备,而用电设备的容许电压 偏移一般为±5%;沿线路的电压降落一般为10%;线路首端电压:

Ua=UN(1+5%);线路末端电压:Ub=UN (1-5%); ULN=(Ua+Ub)∕2=UN 3 发电机的额定电压:发电机通常接于线路始端,因此发电机的额定电压为线路额定电压的1.05 倍UGN =UN(1+5%) 4 变压器的额定电压:变压器一次侧:额定电压取等同于用电设备额定电压,对于直接和发电机相联的变压器,其一次侧额定电压等于发电机的额定电压即: U1N=UGN =UN(1+5%) 二次侧:相当于电源,额定电压取比线路额定电压高5% 。因变压器二次侧额定电压规定为空载时的电压,而额定负荷下变压器内部电压降落约为5%。为使正常时变压器二次侧电压较线路额定电压高5%,变压器二次侧额定电压取比线路额定电压高10%。 6、电力系统的中性点接地方式有哪几种?各应用在哪些场合? 电力系统的中性点接地方式:一:不接地(小电流接地)1 中性点不接地(中性点绝缘)2 中性点经消弧线圈接地 二:直接接地(大接地电流):1 中性点直接接地 110KV 及以上的系统直接接地 60KV 及以下的系统不接地 1)当容性电流超过下列值时采用消弧线圈接地 3~6kV 电力网 (接地电流 >30A) 10kV 电力网 (接地电流 > 20A) 35~60kV 电力网 (接地电流 > 10A) 2)其它情况采用中性点不接地

有机化学实验思考题答案

1、蒸馏有何应用?恒沸混合物能否用蒸馏法分离? 2、在蒸馏装置中,把温度计水银球插至液面上或温度计水银球上端在蒸馏头侧管下限的水平线以上或以下,是否正确?为什么? 3、蒸馏前加入沸石有何作用?如果蒸馏前忘记加沸石,能否立即将沸石加至将近沸腾的液体中?当重新进行蒸馏时,用过的沸石能否继续使用? 1、答:蒸馏过程主要应用如下: (1)分离沸点有显著区别(相差30℃以上)的液体混合物。 (2)常量法测定沸点及判断液体的纯度。 (3)除去液体中所夹杂的不挥发性的物质。 (4)回收溶剂或因浓缩溶液的需要而蒸出部分的溶剂。 恒沸混合物不能用蒸馏法分离。 2、答:都不正确。温度计水银球上端应与蒸馏头侧管的下限在同一水平线上,以保证在蒸馏时水银球完全被蒸气所包围,处于气液共存状态,才能准确测得沸点。 3、答:蒸馏前加入沸石的作用是引入气化中心,防止液体过热暴沸,使沸腾保持平稳。如果蒸馏前忘记加沸石,决不能立即将沸石加至将近沸腾的液体中,因为这样往往会引起剧烈的暴沸泛液,也容易发生着火等事故。应该待液体冷却至其沸点以下,再加入沸石为妥。当重新进行蒸馏时,用过的沸石因排出部分气体,冷却后孔隙吸附了液体,因而可能失效,不能继续使用,应加入新的沸石。 1、测定熔点时,若遇下列情况将产生什么结果? (1)熔点管壁太厚。

(2)熔点管不洁净。 (3)样品未完全干燥或含有杂质。 (4)样品研得不细或装得不紧密。 (5)加热太快。 2、为什么要求熔点的数据要有两个以上的重复?要达到此要求,操作上须注意些什么? 3、两个样品,分别测定它们的熔点和将它们按任何比例混合后测定的熔点都是一样的,这说明什么? 1、答:结果分别如下: (1)熔点管壁太厚,将导致所测熔点偏高。 (2)熔点管不洁净,将导致所测熔点偏低,熔程变宽。 (3)样品未完全干燥或含有杂质,将导致所测熔点偏低,熔程变宽。 (4)样品研得不细或装得不紧密,将导致所测熔点偏高,熔程变宽。 (5)加热太快,将导致熔点偏高。 2、答:为了减少误差。要达到此要求,不可将已测样品冷却固化后再作第二次测定。每次应更换新的样品管,重新测定。 3、答:这说明两个样品是同一化合物。 1、重结晶一般包括哪几个步骤?各步骤的主要目的是什么?

C语言程序设计试题集与答案解析

一.填空 1. 每个C程序都必须有且仅有一个________ 函数。 2. C语言程序开发到执行通常要经过6个阶段即编辑、预处理、________、链接、加载和执行。 3. 软件是程序,以及______、使用和维护所需要的所有文档。 4. 国标中规定:“计算机程序是按照具体要求产生的适合于计算机处理的_________”。 5. 程序设计语言按照书写形式,以及思维方式的不同一般分为低级语言和________两大类。 6. C语言是由________组成的。 7. C语言的函数可分为主函数main、标准库函数和_________。 8. 一个函数是由两部分组成的,即:________和函数体。 9. 编译是将C语言所编写的源程序________成机器代码,也称为建立目标代码程序的过程。 10. 程序是由某种程序设计语言编制出来,体现了编程者的控制思想和对计算机执行操作 的要求。不同的任务功能,就会需求不同的软件程序,如:控制计算机本身软硬件协调工作,并使其设备充分发挥效力,方便用户使用的系统软件程序,称为操作系统;而为办公自动化(OA)、管理信息系统(MIS)、人工智能、电子商务、网络互联等等应用而开发的软件程序,统称为_________。 11. 机器语言是以__________形式表示的机器基本指令的集合,是计算机系统唯一不需要翻译可以直接识别和执行的程序设计语言。 12. 与机器语言相比,使用汇编语言来编写程序可以用_______来表示指令的操作码和操作对 象,也可以用标号和符号来代替地址、常量和变量。

13. 在编译程序之前,凡以____开头的代码行都先由预处理程序预处理。 14. C程序的执行均是由执行_________开始。 15. 函数体即为包含在{}内的部分。它分为________和为完成功能任务由若干个C 语句 组成的执行部分。 16. C语言程序中一条简单语句是以________字符作为结束符的。 17. C语言是结构化、________的程序设计语言。 18. 由于计算机硬件不能直接识别高级语言中的语句,因此,必须经过“_______程序”,将用高级语言编写的程序翻译成计算机硬件所能识别的机器语言程序方可执行。 19. 用高级语言编写的程序需翻译成计算机硬件所能识别的机器语言程序方可执行。所以 说,用高级语言进行程序设计,其编程效率高,方便易用,但_______没有低级语言高。 20.

电路习题集及答案

第一章 电路的基本概念和基本定律 1.1指出图(a )、(b )两电路各有几个节点?几条支路?几个回路?几个网孔? (a) (b) 习题1.1电路 解:(a )节点数:2;支路数:4;回路数:4;网孔数:3。 (b )节点数:3;支路数:5;回路数:6;网孔数:3。 1.2标出图示电路中,电流、电动势和电压的实际方向,并判断A 、B 、C 三点电位的高低。 解:电流、电动势和电压的实际方向如图所示: A 、 B 、 C 三点电位的比较: C B A V V V >> 1.3如图所示电路,根据以下各种情况,判断A 、C 两点电位的高低。 解:(1) C A V V > (2)C A V V > (3)无法判断 1.4有人说,“电路中,没有电压的地方就没有电流,没有电流的地方也就没有电压”。这句话对吗?为什么? 解:不对。因为电压为零时电路相当于短路状态,可以有短路电流;电流为零时电路相当于开路状态,可以有开路电压, 1.5求图示电路中,A 点的电位。

(a ) (b ) 习题1.5电路 解:(a )等效电路如下图所示: (b )等效电路如下图所示: 1.6如图所示电路,求开关闭合前、后,AB U 和CD U 的大小。 1.7求图示电路中,开关闭合前、后A 点的电位。

解:开关闭合时,等效电路如图所示: 开关打开时,等效电路如图所示: 1.8如图所示电路,求开关闭合前及闭合后的AB U、电流1I、2I和3I的大小。 1.9如图所示电路,电流和电压参考方向如图所示。求下列各种情况下的功率,并说明功率的流向。 (1) V 100 A, 2= =u i,(2)V 120 A, 5= - =u i, (3) V 80 A, 3- = =u i,(4)V 60 A, 10- = - =u i 解:(1)A: ) ( 200提供功率 W ui p- = - =; B:) ( 200吸收功率 W ui p= = (2)A: ) ( 600吸收功率 W ui p= - =; B:) ( 600提供功率 W ui p- = = (3)A: ) ( 240吸收功率 W ui p= - =; B:) ( 240提供功率 W ui p- = =

(完整版)分析化学实验思考题答案

分析化学实验思考题答案

实验二滴定分析基本操作练习 1.HCl和NaOH标准溶液能否用直接配制法配制?为什么? 由于NaOH固体易吸收空气中的CO2和水分,浓HCl的浓度不确定,固配制HCl和NaOH 标准溶液时不能用直接法。 2.配制酸碱标准溶液时,为什么用量筒量取HCl,用台秤称取NaOH(S)、而不用吸量管和分析天平? 因吸量管用于标准量取需不同体积的量器,分析天平是用于准确称取一定量的精密衡量仪器。而HCl的浓度不定, NaOH易吸收CO2和水分,所以只需要用量筒量取,用台秤称取NaOH即可。 3.标准溶液装入滴定管之前,为什么要用该溶液润洗滴定管2~3次?而锥形瓶是否也需用该溶液润洗或烘干,为什么? 为了避免装入后的标准溶液被稀释,所以应用该标准溶液润洗滴管2~3次。而锥形瓶中有水也不会影响被测物质量的变化,所以锥形瓶不需先用标准溶液润洗或烘干。 4.滴定至临近终点时加入半滴的操作是怎样进行的? 加入半滴的操作是:将酸式滴定管的旋塞稍稍转动或碱式滴定管的乳胶管稍微松动,使半滴溶液悬于管口,将锥形瓶内壁与管口接触,使液滴流出,并用洗瓶以纯水冲下。 实验三 NaOH和HCl标准溶液的标定 1.如何计算称取基准物邻苯二甲酸氢钾或Na2CO3的质量范围?称得太多或太少对标定有何影响? 在滴定分析中,为了减少滴定管的读数误差,一般消耗标准溶液的体积应在20—25ml 之间,称取基准物的大约质量应由下式求得: 如果基准物质称得太多,所配制的标准溶液较浓,则由一滴或半滴过量所造成的误差就较大。称取基准物质的量也不能太少,因为每一份基准物质都要经过二次称量,如果每次有±0.1mg的误差,则每份就可能有±0.2mg的误差。因此,称取基准物质的量不应少于0.2000g,这样才能使称量的相对误差大于1‰。 2.溶解基准物质时加入20~30ml水,是用量筒量取,还是用移液管移取?为什么?因为这时所加的水只是溶解基准物质,而不会影响基准物质的量。因此加入的水不需要非常准确。所以可以用量筒量取。 3.如果基准物未烘干,将使标准溶液浓度的标定结果偏高还是偏低? 如果基准物质未烘干,将使标准溶液浓度的标定结果偏高。 4.用NaOH标准溶液标定HCl溶液浓度时,以酚酞作指示剂,用NaOH滴定HCl,若NaOH 溶液因贮存不当吸收了CO2,问对测定结果有何影响? 用NaOH标准溶液标定HCl溶液浓度时,以酚酞作为指示剂,用NaOH滴定HCl,若NaOH 溶液因贮存不当吸收了CO2,而形成Na2CO3,使NaOH溶液浓度降低,在滴定过程中虽然其中的Na2CO3按一定量的关系与HCl定量反应,但终点酚酞变色时还有一部分NaHCO3末反应,所以使测定结果偏高。 实验四铵盐中氮含量的测定(甲醛法)

C程序设计第七章课后练习答案

C程序设计(第三版)谭浩强著课后习题答案第7章 2009-05-16 10:56 7.7 打印“魔方阵”。所谓魔方阵是指这样的方阵,它的每一行、每一列和对角线之 和均相等。例如,三阶魔方阵为 8 1 6 3 5 7 4 9 2 要求打印出由1 到n2 的自然数构成的魔方阵。 /******************************************************************** **算法思路:魔方阵中各数的排列规律如下: **(1)将1放在第一行中间一列 **(2)从2开始直到n×n止各数依次按下列规则存放:每一个数存放的行比前一个数的** 行数减1,列数加1 **(3)如果上一个数的行数为1,则下一个数的行数为n(指最下一行) **(4)当上一个数的列数为n时,下一个数的列数应为1,行数减1 **(5)如果按上面的规则确定的位置数已有数,或者上一个数是第1行第n列时,则把 ** 下一个数放在上一个数的下面 ********************************************************************/ #include void main(){ int a[16][16],i,j,k,p,m,n; /*初始化*/ p=1; while(p==1){ printf("input n.(0n)){

c语言程序设计第五版习题答案

习题解析与答案 第1章C语言概述 一.简答题 1.概述C语言的主要特点。 【解答】 (1)语言简洁、紧凑,使用方便、灵活。 (2)数据类型丰富,表达能力强。 (3)运算符多样。C语言中的运算符包含的范围非常广泛。 (4)具有结构化的控制语句。如if…else语句、while语句、do while语句、switch 语句、for语句。 (5)允许直接访问物理地址。C语言中含有的位和指针运算,能够直接对内存地址进行访问操作。 (6)所生成的目标代码质量高,可移植性好。 2.构成C语言程序的基本单位是什么?它由哪几部分组成? 【解答】函数是构成C语言程序的基本单位。一个完整的C程序一般由文件包含、宏定义、函数说明、变量和一个或若干个函数组成。 3.C语言程序的运行一般要经过哪几个步骤? 【解答】(1)编辑;(2)编译;(3)连接,生成EXE文件;(4)执行。 二.运行程序写结果 1.输入下面程序并运行。 main() { int a1,a2,x; a1=100; a2=50; x=a1-a2; printf(″x=%d\n″,x); } 【解答】运行结果为:x=50 2.输入下面程序并运行。 main() { int a1,a2,x; a1=10; a2=20; x=a1*a2; printf(″a1=%d,a2=%d\n″,a1,a2); printf(″x=%d\n″,x); } 【解答】运行结果为:a1=10,a2=20 x=200 3.输入下面程序并运行。

#include main() { printf("******\n"); printf(" *****\n"); printf(" ****\n"); printf(" ***\n"); printf(" **\n"); printf(" *\n"); } 【解答】运行结果为:****** ***** **** *** ** * 思考:可以修改程序,使之输出平行四边形,等腰三角形等图形。 三.编程题 1.参照本章例题,编写一个C程序,用于显示如下信息: ************************* I love C programs! ************************* 【分析与提示】 ①要有文件包含语句#include 。C语言中没有数据的输入、输出等功能,数据的输入、输出都是通过调用系统提供的库函数scanf和printf等来实现的。这些函数的说明都包括在stdio.h文件中。 ②main是主函数的名称。用{}括起来的内容是函数体,函数体由若干条语句组成,这是计算机要执行的部分,每条语句以分号“;”结束。 ③注意显示的信息有三行,所以要用到换行符“\n”。 参考代码: #include main() { printf("************************\n"); printf(" I love C programs! \n"); printf("************************\n"); }

实验思考题参考答案

实验思考题参考答案 实验Fe(OH)3胶体的制备、破坏、分离 1.常压过滤时滤纸为什么要撕去一角?答:使滤纸紧贴玻璃漏斗,有利于排出滤纸与玻璃漏斗之间气泡,形成液柱。 2.抽滤时剪好的滤纸润湿后略大于布氏漏斗的内径、或剪的不圆周边凸出部分贴在布氏漏斗内壁上,对抽滤有何影响?为什么?答:会造成漏虑。滤纸大于布氏漏斗内径会造成滤纸折叠,不能紧贴布氏漏斗。 3.抽滤时,转移溶液之前为什么要先稍微抽气,而不能在转移溶液以后才开始 抽气?答:使滤纸紧贴布氏漏斗,以免造成漏虑。 4. 沉淀物未能铺满布氏漏斗底部、滤饼出现裂缝、沉淀层疏松不实,对抽干效果有什么影响?为什么?如何使沉淀抽得更干爽?答:固液分离效果不好;漏气使压差变小;用药勺铺平、压实沉淀物再抽滤。 由胆矾精制五水硫酸铜 1.结晶与重结晶分离提纯物质的根据是什么?如果被提纯物质是NaCl 而不是CuSO4·5H2O,实验操作上有何区别? 答:根据物质溶解度随温度变化不同。NaCl 的溶解度随温度变化很小不能用重结晶的办法提纯,要用化学方法除杂提纯。 2.结晶与重结晶有何联系和区别?实验操作上有何不同?为什么? 答:均是利用溶解度随温度变化提纯物质;结晶浓缩度较高(过饱和溶液),重结晶浓缩度较低(饱和溶液),且可以进行多次重结晶。结晶一般浓缩到过饱和溶液,有晶膜或晶体析出,冷却结晶;重结晶是在近沸状态下形成饱和溶液,冷却结晶,不允许浓缩。

3.水浴浓缩速度较慢,开始时可以搅拌加速蒸发,但临近结晶时能否这样做? 答:搅拌为了加快水分蒸发;对于利用晶膜形成控制浓缩程度,在邻近结晶时不能搅拌。否则无法形成晶膜。 4.如果室温较低,你准备采用什么措施使热过滤能顺利进行?答:预热漏斗、 分批过滤、保温未过滤溶液。 5.浓缩和重结晶过程为何要加入少量H2SO4?答:防止防止Fe3+水解。 粗盐提纯 1.为什么说重结晶法不能提纯得到符合药用要求的氯化钠?为什么蒸发浓缩时 氯化钠溶液不能蒸干? 答:NaCl 的溶解度随温度变化很小不能用重结晶的办法提纯,药用氯化钠不仅要达到纯度要求,还要符合药用要求。不能浓缩至干NaCl 溶液,是为了除去KCl。 2.用化学法除去SO42-、Mg2+ 、Ca2+的先后顺序是否可以倒置过来?为什么? 答:不能,除杂要求为除去杂质引入的离子必须在后续的除杂过程中除去,先除去Mg2+ 、Ca2+后除SO42-,无法除去Ba2+。 3.用什么方法可以除去粗盐中不溶性杂质和可溶性杂质?依据是什么? 答:不溶性杂质用过滤方法;可溶性杂质用化学方法除杂。依据:溶度积。 醋酸解离度和电离常数测定 1.不同浓度的HAc 溶液的溶解度α是否相同?为什么?用测定数据说明弱电解质解离度随浓度变化的关系。 答:不同,因K a,θ AH 。c↑,α↓。 c 2.测定不同浓度的HAc 溶液的pH 值时,为什么按由稀到浓的顺序?答:平衡块,减小由于润洗不到位而带来的误差。

(完整版)C语言程序设计练习及答案

《C语言程序设计》练习及答案 得分评卷人复查人 一、单选题,每小题1分,共60分(将正确答案的序号写在题目的括号中)。 1、结构化程序设计的三种基本控制结构是(D )。 A、主程序、子程序、函数 B、输入、处理、输出 C、调用,返回,转移 D、顺序、选择、循环 2、下列关于C程序变量的叙述, ( D )是错误的。 A、变量名必须由字母或下划线开头。 B、程序中的变量必须在被使用之前定义。 C、不同的基本类型的变量之间可以混合运算。 D、变量的数据类型决定变量的"作用域"。 3、能将C语言编写的源程序转换为目标程序的软件是(C )。 A、编辑程序 B、汇编程序 C、编译程序 D、解释程序 4、以下符号中,合法的用户标识符是( D )。 A、-p B、int C、3ab D、_xt_ 5、以下选项中,与m=n++完全等价的表达式是( C )。 A、m=++n B、m+=n+1 C、m=n, n=n+1 D、n=n+1,m=n 6、若有定义:int aa[8];。则以下表达式中不能代表数组元aa[1]的地址的是(C )。 A、&aa[0]+1 B、&aa[1] C、&aa[0]++ D、aa+1 7、表达式!5&(7+3)&&(4+5)的值是(A)。 A、0 B、1 C、5 D、9 8、以下选项中非法的C语言表达式是(A )。 A、x+1=x+1 B、0<=x<100 C、i=j==0 D、(char)(65+3) 9、在TURBO C中, int类型变量所占字节数是(B )。 A、1 B、2 C、4 D、8 10、C语言中基本的数据类型包括(B)。 A、整型,实型,逻辑型 B、整型,实型,字符型

电路原理实验思考题答案

实验一电阻元件伏安特性的测绘 1、设某器件伏安特性曲线的函数式为I=f(U),试问在逐点绘制曲线时,其坐标变量应如 何放置? 在平面内绘制xOy直角坐标系,以x轴为电压U,y轴为电流I,观察I和U的测量数据,根据数据类型合理地绘制伏安特性曲线。 2、稳压二极管与普通二极管有何区别,其用途如何? 普通二极管的主要特性是单向导电性,也就是在正向电压的作用下,导电电阻很 小;而在反向电压作用下导电电阻极大或无穷大。正因为二极管具有上述特性, 电路中常把它用在整流。稳压二极管的特点就是加反向电压击穿后,其两端的电压基本保持不变。稳压二极管用来稳压或在串联电路中作基准电压。普通二极管和稳压二极管都是PN半导体器件,所不同的是普通二极管用的是单向导电性, 稳压二极管是利用了其反向特性,在电路中反向联接。 实验二网络的等效变换于电源的等效变换 1、通常直流稳压电源的输出端不允许短路,直流恒流源的输出端不允许开路,为什么? 2 P U 如果电压源短路,会把电源给烧坏,相当于负载无限小,功率R为无穷大。 2 如果电流源开路,相当于负载无穷大,那么功率P I R为无穷大,也会烧坏电流源。 2、电压源与电流源的外特性为什么呈下降趋势,稳压源和恒流源的输出在任何负载下是 否保持恒值? 因为电压源有一定内阻,随着负载的增大,内阻的压降也增大,因此外特性呈下降趋势。电流源实际也有一个内阻,是与理想恒流源并联的,当电压增加时,同样由于内阻的存在,输出的电流就会减少,因此,电流源的外特性也呈 下降的趋势。不是。当负载大于稳压源对电压稳定能力时,就不能再保持电压稳定了,若负载进一步增加,最终稳压源将烧坏。实际的恒流源的控制能力一般都有一定的范围,在这个范围内恒流源的恒流性能较好,可以基本保持恒流,但超出恒流源的恒流范围后,它同样不具有恒流能力了,进一步增加输出的功率,恒流源也将损坏。 实验三叠加原理实验 1、在叠加原理实验中,要令U1、U2分别单独作用,应如何操作?可否直接 将不作用的电源(U1或U2)置零连接? 在叠加原理实验中,要令U1单独作用,则将开关K1投向U1侧,开关K2投向 短路侧;要令U2单独作用,则将开关K1投向短路侧,开关K2投向U2侧。不

化工实验思考题答案

化工基础实验思考题答案 实验一流体流动过程中的能量变化 1、实验为什么要使高位水槽的水保持溢流? 答:保持溢流可使流体稳定流动,便于读数,同时伯努利方程只在流体稳定流动时才适用。 2、操作本实验装置应主意什么? 答:1)开启电源之前,向泵中灌水 2)高位水槽水箱的水要保持溢流 3)赶尽玻璃管中气泡 4)读数时多取几组值,取平均值 实验二流体流动形态的观察与测定 1、在实验中测定的雷诺数与流动形态的关系如何?如果出现理论与实际的偏差,请分析理由 答:1)层流时,理论与实际符合 2)过渡流测量值与理论值稍有偏差 偏差分析:(1)孔板流量计的影响 (2)未能连续保持溢流 (3)示踪管未在管中心 (4)示踪剂流速与水的流速不一致 2、本实验中的主意事项有那些? 答:(1)保持溢流 (2)玻璃管不宜过长 (3)示踪管在中心

实验三节流式流量计性能测定实验 1、你的实验结果可以得到什么结论? 答:流速较大或较小时,流量系数C并不稳定,所以性能并不很好 2、实验中为什么适用倒置U型管? 答:倒置的U形管作压差计,采用空气作指示液,无需重新装入指示液,使用方便 实验四连续流动反应器实验流程图 1、测定停留时间分布函数的方法有哪几种?本实验采用的是哪种方法? 答:脉冲法、阶跃法、周期示踪法和随机输入示踪法。本实验采用脉冲示踪法。 2、模型参数与实验中反应釜的个数有何不同,为什么? 答:模型参数N的数值可检验理想流动反应器和度量非理想流动反应器的返混程度。当实验测得模型参数N值与实际反应器的釜数相近时,则该反应器达到了理想的全混流模型。若实际反应器的流动状况偏离了理想流动模型,则可用多级全混流模型来模拟其返混情况,用其模型参数N值来定量表征返混程度。 3、实验中可测得反应器出口示踪剂浓度和时间的关系曲线图,此曲线下的面积有何意义? 答:一定时间内示踪剂的总浓度。 4、在多釜串联实验中,为什么要在流体流量和转速稳定一段时间后才能开始实验? 答:为使三个反应釜均能达到平衡。 实验五换热器传热系数的测定 1、实验误差主要来源那几个方面? 答:1)读数不稳定

C语言程序设计第二版习题参考答案

C语言程序设计第二版 习题参考答案 Document serial number【LGGKGB-LGG98YT-LGGT8CB-LGUT-

C语言程序设计习题参考答案 习题 1 一、判断题 1.在计算机中,小数点和正负号都有专用部件来保存和表示。 2.二进制是由0和1两个数字组成的进制方式。 3.二进制数的逻辑运算是按位进行的,位与位之间没有进位和借位的关系。 4.在整数的二进制表示方法中,0的原码、反码都有两种形式。 5.有符号数有三种表示法:原码、反码和补码。 6.常用字符的ASCII码值从小到大的排列规律是:空格、阿拉伯数字、大写英文字母、小写英文字母。 解:1.F2.T 3.T 4.T 5.T 6.T 二、单选题 1.在计算机中,最适合进行数值加减运算的数值编码是。 A. 原码 B. 反码 C. 补码 D. 移码 2.已知英文小写字母m的ASCII码为十进制数109,则英文小写字母y的ASCII 码为十进制数。 A. 112 B. 120 C. 121 D. 122 3.关于ASCII码,在计算机中的表示方法准确地描述是。 A. 使用8位二进制数,最右边一位为1 B. 使用8位二进制数,最左边一位为1 C. 使用8位二进制数,最右边一位为0 D. 使用8位二进制数,最左边一位为0 4.设在机器字长4位,X=0111B,Y=1011B,则下列逻辑运算中,正确的是 ___________。 A. X∧Y=1000 B. X∨Y=1111 C. X⊕Y=0011 D. ˉY=1000 5.下列叙述中正确的是()。 A.高级语言就是机器语言 B.汇编语言程序、高级语言程序都是计算机程序,但只有机器语言程序才是计算机可以直接识别并执行的程序 C.C语言因为具有汇编语言的一些特性,所以是汇编语言的一种 D.C源程序经过编译、连接,若正确,执行后就能得到正确的运行结果6.用C语言编写的源程序经过编译后,若没有产生编译错误,则系统将()。 A.生成可执行文件B.生成目标文件 C.输出运行结果D.自动保存源文件 7.下列叙述中不正确的是()。 A.main函数在C程序中必须有且只有一个 B. C程序的执行从main函数开始,所以main函数必须放在程序最前面 C. 函数可以带参数,也可以不带参数。

大学物理实验思考题答案

实验一:用三线摆测物体的转动惯量 1. 是否可以测摆动一次的时间作周期值?为什么? 答:不可以。因为一次测量随机误差较大,多次测量可减少随机误差。 2. 将一半径小于下圆盘半径的圆盘,放在下圆盘上,并使中心一致,讨论此时三线摆的周期和空载时的周期相比是增大、减小还是不一定?说明理由。 答:当两个圆盘的质量为均匀分布时,与空载时比较,摆动周期将会减小。因为此时若把两盘看成为一个半径等于原下盘的圆盘时,其转动惯量I0小于质量与此相等的同直径的圆盘,根据公式(3-1-5),摆动周期T0将会减小。 3. 三线摆在摆动中受空气阻尼,振幅越来越小,它的周期是否会变化?对测量结果影响大吗?为什么? 答:周期减小,对测量结果影响不大,因为本实验测量的时间比较短。 [实验二] 金属丝弹性模量的测量 1. 光杠杆有什么优点,怎样提高光杠杆测量的灵敏度? 答:优点是:可以测量微小长度变化量。提高放大倍数即适当地增大标尺距离D或适当地减小光杠杆前后脚的垂直距离b,可以提高灵敏度,因为光杠杆的放大倍数为2D/b。 2. 何谓视差,怎样判断与消除视差? 答:眼睛对着目镜上、下移动,若望远镜十字叉丝的水平线与标尺的刻度有相对位移,这种现象叫视差,细调调焦手轮可消除视差。 3. 为什么要用逐差法处理实验数据? 答:逐差法是实验数据处理的一种基本方法,实质就是充分利用实验所得的数据,减少随机误差,具有对数据取平均的效果。因为对有些实验数据,若简单的取各次测量的平均值,中间各测量值将全部消掉,只剩始末两个读数,实际等于单次测量。为了保持多次测量的优越性,一般对这种自变量等间隔变化的情况,常把数据分成两组,两组逐次求差再算这个差的平均值。 [实验三]

C语言程序设计第二版第四章第七章课后答案

1、输入函数scanf的参数错误,应该为:scanf("%f",&k); 2、|1234 1234 | 3、ff10 4、1,3,1 5、原字符串左边加空格再加字符串本省,字符个数总和为5个 6、scanf("%d,%d,%c,%c",&a1,&a2,&c1,&c2); 7、 printf("a+b=%d\n",a+b); printf("a-b=%d\n",a-b); printf("a*b=%d\n",a*b); printf("a/b=%d\n",a/b); printf("(float)a/b=%f\n",(float)a/b); printf("a%b=%d\n",a%b); 8、 void main() { float r; float s,c; printf("please input the number:"); scanf("%f",&r); if(r>=0) { s = 3.14*r*r; c = 2*3.14*r; printf("s = %f, c = %f\n",s,c); } else printf("you input number is error!"); } 9 void main() {int n; printf("please input the number:"); scanf("%d",&n); if(n>=100 && n <= 999) printf("%d%d%d",n%10,(n/10)%10,n/100); else printf("you input number is error!"); } 10、 void main() { int i,j,k; scanf("%d,%d,%d",&i,&j,&k); ((i%2 != 0?1:0) + (j%2 != 0?1:0)+(k%2 != 0?1:0)) == 2?printf("YES\n"):printf("NO\n"); } 11、 void main()

实验思考题答案

实验一燃烧热的测定 1.在本实验中,哪些是系统?哪些是环境?系统和环境间有无热交换?这些热交换对实验结果有何影响?如何校正? 提示:盛水桶内部物质及空间为系统,除盛水桶内部物质及空间的热量计其余部分为环境,系统和环境之间有热交换,热交换的存在会影响燃烧热测定的准确值,可通过雷诺校正曲线校正来减小其影响。 2.固体样品为什么要压成片状?萘和苯甲酸的用量是如何确定的? 提示:压成片状有利于样品充分燃烧;萘和苯甲酸的用量太少测定误差较大,量太多不能充分燃烧,可根据氧弹的体积和内部氧的压力确定来样品的最大用量。 3.试分析样品燃不着、燃不尽的原因有哪些? 提示:压片太紧、燃烧丝陷入药片内会造成燃不着;压片太松、氧气不足会造成燃不尽。 4.试分析测量中影响实验结果的主要因素有哪些?本实验成功的关键因素是什么? 提示:能否保证样品充分燃烧、系统和环境间的热交换是影响本实验结果的主要因素。本实验成功的关键:药品的量合适,压片松紧合适,雷诺温度校正。 5.使用氧气钢瓶和氧气减压器时要注意哪些事项? 提示:阅读《物理化学实验》教材P217-220 实验二凝固点降低法测定相对分子质量 1.什么原因可能造成过冷太甚?若过冷太甚,所测溶液凝固点偏低还是偏高?由此所得萘的相对分子质量偏低还是偏高?说明原因。 答:寒剂温度过低会造成过冷太甚。若过冷太甚,则所测溶液凝固点偏低。根据公式和可知由于溶液凝固点偏低,?T f偏大,由此所得萘的相对分子质量偏低。 2.寒剂温度过高或过低有什么不好? 答:寒剂温度过高一方面不会出现过冷现象,也就不能产生大量细小晶体析出的这个实验现象,会导致实验失败,另一方面会使实验的整个时间延长,不利于实验的顺利完成;而寒剂温度过低则会造成过冷太甚,影响萘的相对分子质量的测定,具体见思考题1答案。 3.加入溶剂中的溶质量应如何确定?加入量过多或过少将会有何影响? 答:溶质的加入量应该根据它在溶剂中的溶解度来确定,因为凝固点降低是稀溶液的依数性,所以应当保证溶质的量既能使溶液的凝固点降低值不是太小,容易测定,又要保证是稀溶液这个前提。如果加入量过多,一方面会导致凝固点下降过多,不利于溶液凝固点的测定,另一方面有可能超出了稀溶液的范围而不具有依数性。过少则会使凝固点下降不明显,也不易测定并且实验误差增大。

C语言程序设计习题答案

C 语言程序设计习题答案 习题一 C 语言程序设计概述 一、名词解释 (1)程序P1 (2)程序设计P1 (3)机器语言P1 (4)汇编程序P2 (5)高级语言P2 (6)编译程序P3 (7)解释程序P3 (8)算法P4 (9)结构化的程序设计P9 二、简述题 1. 设计程序时应遵循哪些基本原则?P4 答:正确性、可靠性、简明性、有效性、可维护性、可移植性。 2. 算法的要素是什么?算法具有哪些特点? 答:算法的要素是:操作与控制结构;算法的特点有:有穷性、确定性、有效性、有零个或多个输入、有一个或多个输出。 3. 算法的表示形式有哪几种? 答:算法的表示形式有:自然语言、传统流程图、伪代码、结构化的流程图(N_S 流程图,盒图)。 4. 有哪三种基本结构? 答:三种基本结构是:顺序结构、选择结构和循环结构。 5. 传统流程图与N-S 流程图最大的区别是什么? 答:N-S 流程图去掉了在传统流程图中常用的流程线,使得程序的结构显得更加清晰、简单。 三、用传统流程图、N-S 图分别表示求解以下问题的算法。 1. 有3个数a ,b ,c ,要求按由大到小的顺序把它们输出。 2. 依次将10个数输入,求出其中最大的数 和最小的数并输出。 3. 求1+2+3+…+100的值。

5. 求下列分段函数的值。 6. 求100~200之间的所有素数。 7. 求一元二次方程ax 2+bx+c=0的根。分别考虑d=b 2-4ac 大于0、等于0和小于0三种情况。 四、注释下面C 程序的各个组成部分。 main() /*主函数 */ { /*程序开始 */ int a,k,m; /*定义三个用来存放整数的变量 */ a=10; /*将整数10赋值给变量a */ k=2; /*将整数2赋值给变量k */ m=1; /*将整数1赋值给变量1 */ a=(k+m)*k/(k-m); /*先求出算术表达式的值,并将其赋值给变量a */ printf("%d\n",a); /*在屏幕上打印出变量a 的值 */ } /*程序结束 */ 习题二 数据类型、运算符与表达式 一、选择题 1~10:BCDCB DDBCA 11~20: ADDAA DBADC 21~28: DABAD CDD Y= 3X (X<1) 4X-1 (X=1) 5(X-1)+6 (1

电路原理课后习题答案

第五版《电路原理》课后作业 第一章“电路模型和电路定律”练习题 1-1说明题1-1图(a)、(b)中:(1)u、i的参考方向是否关联?(2)ui乘积表示什么功率? (3)如果在图(a)中u>0、i<0;图(b)中u>0、i>0,元件实际发出还是吸收功率? (a)(b) 题1-1图 解 (1)u、i的参考方向是否关联? 答:(a) 关联——同一元件上的电压、电流的参考方向一致,称为关联参考方向; (b) 非关联——同一元件上的电压、电流的参考方向相反,称为非关联参考方向。(2)ui乘积表示什么功率? 答:(a) 吸收功率——关联方向下,乘积p = ui > 0表示吸收功率; (b) 发出功率——非关联方向,调换电流i的参考方向之后,乘积p = ui < 0,表示 元件发出功率。 (3)如果在图(a) 中u>0,i<0,元件实际发出还是吸收功率? 答:(a) 发出功率——关联方向下,u > 0,i < 0,功率p为负值下,元件实际发出功率; (b) 吸收功率——非关联方向下,调换电流i的参考方向之后,u > 0,i > 0,功率p为正值下,元件实际吸收功率; 1-4 在指定的电压u和电流i的参考方向下,写出题1-4图所示各元件的u和i的约束方程(即VCR)。 (a)(b)(c) (d)(e)(f) 题1-4图 解(a)电阻元件,u、i为关联参考方向。 由欧姆定律u = R i = 104 i (b)电阻元件,u、i为非关联参考方向 由欧姆定律u = - R i = -10 i (c)理想电压源与外部电路无关,故u = 10V (d)理想电压源与外部电路无关,故u = -5V

相关主题
文本预览
相关文档 最新文档