C程序设计实践(共8页).doc

上传人:飞****2 文档编号:14068897 上传时间:2022-05-02 格式:DOC 页数:8 大小:70KB
返回 下载 相关 举报
C程序设计实践(共8页).doc_第1页
第1页 / 共8页
C程序设计实践(共8页).doc_第2页
第2页 / 共8页
点击查看更多>>
资源描述

《C程序设计实践(共8页).doc》由会员分享,可在线阅读,更多相关《C程序设计实践(共8页).doc(8页珍藏版)》请在taowenge.com淘文阁网|工程机械CAD图纸|机械工程制图|CAD装配图下载|SolidWorks_CaTia_CAD_UG_PROE_设计图分享下载上搜索。

1、精选优质文档-倾情为你奉上C+程序设计实践上机指导书(第八次)专业 计算机科学与技术 班级 学号 姓名 沈阳工程学院信息学院实践成绩评价说明1) 上机前充分准备实践材料,对上机内容有程序草稿。(10分)2) 独立完成实践任务,对实践过程非常清晰。(30分)3) 认真理解知识点,能够与理论知识相结合。(10分)4) 在机房遵守上机守则,接受实践指导教师的监督与管理。(20分)5) 认真填写实践指导书,写出实践小结。(10分)6) 在实践中具备一定的创新思想,能够主动与指导教师探讨。(5分)7) 加大实践工作量,主动完成实践指导书中的选做题目。(5分)8) 掌握程序调试的方法,认真完成程序调试工作

2、,使程序能够运行(10分)。上机八 类与对象(四)一、目的1、学习类的组合; 2、体会类的组合的构造函数的使用方式; 3、理解利用友元关系实现数据共享的机制4. 掌握类的友元函数以及友元类的实现方法;二、要求:1. 在上课之前,每一个同学必须将题目、程序编写完毕,做好充分的准备。2. 所有环节均由每位同学独立完成,严禁抄袭他人结果。三、步骤和内容1、定义点类,使用友元函数计算两点间的距离,体会友元函数的使用2、在题目1的基础上,设计一个类Trig,给定三角形的三个定点的坐标(平面直角坐标系)要求:a) 用一个友元函数计算三角形面积。b) 将友元函数存放在一个类中,并将该类修改为类Trig的友元

3、类注:三角形的面积公式为:已知三角形三边a,b,c,则(海伦公式)(p=(a+b+c)/2)S=3. 设计一个类Sample,它有两个私有数据成员a和n(a中元素的个数)。请对a中数据进行排序,并将排序函数作为友元函数或者放在类process中。四、思考题1、在类的组合中,构造函数的声明顺序是怎样的?2、友元关系可以传递么?为什么说不要过多的使用友元关系?五、结果分析1、定义点类,使用友元函数计算两点间的距离,体会友元函数的使用#include#includeusing namespace std;class Trigpublic:Trig(int m,int n)x1=m;y1=n;Trig

4、(double a,double b,double c)x=a;y=b;z=c;friend add(Trig &a,Trig &b,Trig &c,Trig &d)double s1,s2,s3,s4,area1,area2,p,s;s1=sqrt(fabs(a.x1-b.x1)*fabs(a.x1-b.x1)+fabs(a.y1-b.y1)*fabs(a.y1-b.y1);s2=sqrt(fabs(a.x1-c.x1)*fabs(a.x1-c.x1)+fabs(a.y1-c.y1)*fabs(a.y1-c.y1);s3=sqrt(fabs(c.x1-b.x1)*fabs(c.x1-b.x1

5、)+fabs(c.y1-b.y1)*fabs(c.y1-b.y1);s4=0.5*(s1+s2+s3);area1=sqrt(s4*(s4-s1)*(s4-s2)*(s4-s3);p=0.5*(d.x+d.y+d.z); area2=sqrt(p*(p-d.x)*(p-d.y)*(p-d.z); s=area1+area2;return s;private:int x1,y1;double x,y,z;int main()Trig A(1,0),B(0,4),C(0,0),D(3,4,5);double ss;ss=add(A,B,C,D);cout两个三角形面积的和:endl;coutsse

6、ndl;return 0;2、在题目1的基础上,设计一个类Trig,给定三角形的三个定点的坐标(平面直角坐标系)要求:a) 用一个友元函数计算三角形面积。b) 将友元函数存放在一个类中,并将该类修改为类Trig的友元类注:三角形的面积公式为:已知三角形三边a,b,c,则(海伦公式)(p=(a+b+c)/2)S=#include#includeclass Cpoint public: float a1,b1;Cpoint(float i,float j)/构造函数a1=i;b1=j;class triaprivate:double L1,L2,L3,s;public: double area;

7、Cpoint A,B,C;/类Cpoint下的三个对象tria(float a,float b,float c,float d,float e,float f):A(a,b),B(c,d),C(e,f)/初始化列表L1=sqrt(A.a1-B.a1)*(A.a1-B.a1)+(A.b1-B.b1)*(A.b1-B.b1);L2=sqrt(A.a1-C.a1)*(A.a1-C.a1)+(A.b1-C.b1)*(A.b1-C.b1);L3=sqrt(B.a1-C.a1)*(B.a1-C.a1)+(B.b1-C.b1)*(B.b1-C.b1);s=(L1+L2+L3)/2);area=sqrt(s*

8、(s-L1)*(s-L2)*(s-L3); friend void print(tria D);void print(tria D) coutD.areaendl;/三角形面积的输出void main() tria D(4.0,2.0,3.0,4.0,5.0,6.0); print(D);3. 设计一个类Sample,它有两个私有数据成员a和n(a中元素的个数)。请对a中数据进行排序,并将排序函数作为友元函数或者放在类process中。#includeusing namespace std;class process;class Samplepublic:Sample(int n1)n=n1;

9、 a=new intn;friend process;void input()for(int i=0;iai;coutendl;private:int n,*a;class processpublic: void paixu(Sample &s)for(int j=0;js.n-1;j+)for(int i=0;is.ai+1)int t;t=s.ai;s.ai=s.ai+1;s.ai+1=t;coutthe sorted number :endl;for(int i=0;is.n;i+)couts.ait;coutendl;int main()int n;coutinput n number :n;Sample a(n);a.input();process b;b.paixu(a);return 0;六、指导教师评阅成绩专心-专注-专业

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 教案示例

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知淘文阁网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号© 2020-2023 www.taowenge.com 淘文阁