实验2-C++对C的扩充_第1页
实验2-C++对C的扩充_第2页
实验2-C++对C的扩充_第3页
实验2-C++对C的扩充_第4页
实验2-C++对C的扩充_第5页
已阅读5页,还剩4页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

电子信息学院实验报告书课程名:面向对象程序设计题目:实验2C++对C的扩充实验类别:设计研究型班级:BX1004学号:101003040420姓名:施程程评语:评语:实验态度:认真()一般()差()实验结果:正确()部分正确()错()实验理论:掌握()熟悉()了解()不懂()操作技能:强()一般()差()实验报告:好()一般()差()成绩:指导教师:批阅时间:年月日1、实验目的(1)了解在面向过程程序设计中功能的扩充与增强,并善于在编写过程中应用这些新的功能。(2)进一步熟悉在所用的系统上编辑、编译、连接和运行C++程序的方法。

(3)进一步熟悉C++程序的结构和编程方法。2、实验内容要求事先编好解决下面问题的程序,然后上机输入并调试运行。输入以下程序,进行编译,观察编译情况,如果有错误,请修改程序,再进行编译,直到没有错误,然后进行连接和运行,分析运行结果。#include<iostream>

using

namespace

std;intmain(){inta,b;c=add(a,b)

cout<<“a+b=”<<c<<endl;

return0;}int

add(int

x,int

y)

{z=x+y;return(z);}编一个程序,用来求2个或3个正整数中的最大数。用不带默认参数的函数实现。用带有默认参数的函数实现。对比两种方法,分析用带有默认参数的函数的优点和应用场合,总结如何选择默认b参数的值。请分析本题中默认参数的值应该在什么范围。对3个变量按由小到大顺序排序,要求使用变量的引用。使用指针方法使用变量的的引用请总结引用时要注意什么问题。有5个字符串,要求对他们按由小到大的顺序排列,用string方法,

编译一个程序,用同一个函数名对n个数据进行从小到大排序,数据类型可以是整型、单精度型、双精度型。用重载函数实现。用函数模板实现。比较这两种方法各有什么特点,什么情况下可以用函数模板代替重载函数?

3.实验结果(1)程序:#include<iostream>}voidsort(int&i,int&j,int&k){voidchange(int&,int&);if(i>j)change(i,j);if(i>k)change(i,k);if(j>k)change(j,k);}voidchange(int&x,int&y){inttemp; temp=x; x=y; y=temp;}运行结果:变量的“引用”就是变量的别名,引用的作用是为一个变量起另一个名字,以便在需要时可以方便、间接地应用该变量。在引用时要注意:由于引用不是独立的变量,编译系统不给它单独分配存储单元,因此在建立引用时只有声明,没有定义,只是声明它和原有的某一变量的关系。程序:#include<iostream>#include<string>usingnamespacestd;intmain(){inti;stringstr[5]={"shang","hai","string","C++","include"};voidsort(string[]);sort(str);cout<<"thesortedstrings:"<<endl;for(i=0;i<5;i++)cout<<str[i]<<"";cout<<endl;return0;}voidsort(strings[]){inti,j;stringt;for(j=0;j<5;j++)for(i=0;i<5-j;i++)if(s[i]>s[i+1]) {t=s[i];s[i]=s[i+1];s[i+1]=t;}}运行结果:程序1:用重载函数实现#include<iostream>#include<string>usingnamespacestd;voidsort(longa[]){inti,j;longt;for(j=0;j<5;j++)for(i=0;i<5-j;i++)if(a[i]>a[i+1]) {t=a[i];a[i]=a[i+1];a[i+1]=t;}cout<<"thesortednumbers:"<<endl;for(i=0;i<5;i++) cout<<a[i]<<"";cout<<endl;}voidsort(inta[]){inti,j,t;for(j=0;j<5;j++)for(i=0;i<5-j;i++)if(a[i]>a[i+1]) {t=a[i];a[i]=a[i+1];a[i+1]=t;}cout<<"thesortednumbers:"<<endl;for(i=0;i<5;i++) cout<<a[i]<<"";cout<<endl;}voidsort(floata[]){inti,j;floatt;for(j=0;j<5;j++)for(i=0;i<5-j;i++)if(a[i]>a[i+1]) {t=a[i];a[i]=a[i+1];a[i+1]=t;}cout<<"thesortednumbers:"<<endl;for(i=0;i<5;i++) cout<<a[i]<<"";cout<<endl;}intmain(){longa[5]={12345,10000,87663,27958,36754};intb[5]={4,3,7,-5,9};floatc[5]={1.2,-3.4,6.7,-2.6,4.5};sort(a);sort(b);sort(c);return0;}运行结果:程序2:用函数模板实现#include<iostream>#include<string>usingnamespacestd;template<typenameT>voidsort(Ta[]){inti,j,min;Tt;for(i=0;i<5;i++){min=i;for(j=i+1;j<5;j++) if(a[min]>a[j])min=j; t=a[i];a[i]=a[min];a[min]=t;}cout<<"Thesortednumbersare:"<<endl;for(i=0;i<5;i++) cout<<a[i]<<"";cout<<endl<<endl;}intmain(){longa[5]={12345,10000,87663,27958,36754};intb[5]={4,3,7,-5,9};floatc[5]={1.2,-3.4,6.7,-2.6,4.5};sort(a);sort(b);sort(c);return0;}运行结果:用函数模版比重载函数更方便,程序更简洁。但是应注意函数模版只适用于函数的参数个数相同而类型不同,且函数体相同的情况,如果参数的个数不同,则不能用函数模版。4.结果分析与实验体会这是C++的第二次实验,实验内容大多是我们的课后作业,这让我们更

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论