首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
请打开考生文件夹下的解决方案文件proj3,其中包含主程序文件main.cpp和用户定义的头文件Array.h,整个程序包含有XArray类的定义和main主函数的定义。请把主程序文件中的XArray类的成员函数twoMinSum()的定义补充完整,补充的
请打开考生文件夹下的解决方案文件proj3,其中包含主程序文件main.cpp和用户定义的头文件Array.h,整个程序包含有XArray类的定义和main主函数的定义。请把主程序文件中的XArray类的成员函数twoMinSum()的定义补充完整,补充的
admin
2020-04-10
61
问题
请打开考生文件夹下的解决方案文件proj3,其中包含主程序文件main.cpp和用户定义的头文件Array.h,整个程序包含有XArray类的定义和main主函数的定义。请把主程序文件中的XArray类的成员函数twoMinSum()的定义补充完整,补充的内容填写在“//*******333*******”与“//******* 666 *******”两行之间。
经修改后运行程序,得到的输出为:
3 5 7 9 8 6 4 2
5
注意:只允许在“//*******333*******”和“//*******666*******”两行之间填写内容.不允许修改其他任何地方的内容。
//Array.h
#include<iostream>
using namespace std;
class XArray{//数组类
int * a;
int size;
public:
XArray(int b[],int len):size(len)//构造函数
{
a=new int[size];
for(int i=0;i<size;i++)a
=b
;
}
int length()const{return size;}//返回数组长度
int& operator[](int i){//返回下标为i的元素
if(i<0 ||i>=size){
cout<<"下标越界!"<<endl;
delete[]a;
exit(1);
}
return a
;
}
int twoMinSum();//成员函数声明,返回数组a中两个最小元素值之和
~XArray(){delete[]a;}
};
void writeToFile(const char *);//不用考虑此语句的作用
//main.cpp
#include"Array.h"
//返回成员数组a中的两个最小元素值之和
int XArray::twoMinSum()
{
int x1,x2;
if(1ength()<2)exit(1);
if(a[0]<=a[1])
{x1=a[0];x2=a[1];}
else{x1=a[1]; x2=a[0];}
//********333********
//********666********
return x1+x2;
}
void main(){
int a[8]={3,5,7,9,8,6,4,2};
XArray X(a,8);
for(int i=0;i<x.length();i++)
cout<<X
<<’ ’;
cout<<endl<<x.twoMinSum ()<<endl;
writeToFile("");//不用考虑此语句的作用
}
选项
答案
int XArray::twoMinSum() { int x1,x2; if(length()<2)exit(1); if(a[0]<=a[1]){x1=a[0];x2=a[1];} else(x1=a[1];x2=a[0];} //********333******** for(int i=2; i<size;i++){ if(a[i]<x1){ x2=x1; x1=a[i]; }else if(a[i]<x2){ x2=a[i]; } } //********666******** return x1+x2; }
解析
根据题意,twoMinSum成员函数需要在成员a指向的size个数组元素中,找到最小的两个元素x1和x2,返回x1和x2之和。函数首先判断a指向的数组中元素个数是否大于等于2个,接着将a[0]和a[1]两个元素的较小值赋给x1,较大值赋给x2,使得x1始终指向处理过元素中的最小值,x2始终指向处理过元素的次小值;然后从数组a中下标为2的位置开始遍历各个元素,若当前元素a
<x1,说明a
是当前处理过元素中的最小值,x1是次小值;用x1更新x2,再用a
更新x1;若a
>=x1且a
<x2,说明a
是次小值,只更新x2即可;若a
>=x2,则不作处理;完成遍历后,返回x1和x2之和。
转载请注明原文地址:https://kaotiyun.com/show/Fu8p777K
本试题收录于:
二级C题库NCRE全国计算机二级分类
0
二级C
NCRE全国计算机二级
相关试题推荐
虚函数必须是类的()。
以下结构类型可用来构造链表的是______。
若将一个二元运算符重载为类的成员函数,其形参个数应该是______个。
A、 B、 C、 D、 A函数模板定义的一般格式为:Template<typename类型参数>返回类型函数名(模板形参表){函数体}
下面不是C++语言整型常量的是()。
以下不使用线性结构表示实体之间联系的模型的是()。
在计算机软件系统的体系结构中,数据库管理系统位于用户和【】之间。
若磁盘上已存在某个文本文件,其全路径文件名为d:\ncre\test.txt,下列语句中不能打开该文件的是
下面描述中错误的是()。A)系统总体结构图支持软件系统的详细设计B)软件设计是将软件需求转换为软件表示的过程C)数据结构与数据库设计是软件设计的任务之一D)PAD图是软件详细设计的表示工具
随机试题
非血瘀的临床表现是
LHPRL
A、大便清稀,完谷不化,腹部喜温B、大便色黄褐而臭,泻下急迫,肛门灼热C、泻下腹痛,痛势急迫拒按,泻后痛减D、大便时溏时泻,完谷不化,腹痛不甚,喜温喜按E、每因抑郁恼怒或情绪紧张时,即发生腹痛泄泻寒证泄泻的特征是
A.肿痛B.流脓C.脱出D.便秘E.便血肛痈与肛漏的共有症状是
《药品不良反应监测管理办法(试行)》适用于
对于下列起诉,法院应当裁定不予受理或裁定驳回起诉的是()。
破产犯罪的特征。
()是我们党实事求是、光明磊落和对人民高度负责精神的体现。
根据下表,回答96-100题。与2005年同期相比,上海港2008年7月货运吞吐量占沿海港口合计吞吐量的比重约:
InGeorgeOrwell’sAnimalFarmthemightycart-horse,Boxer,inspirestheotheranimalswithhisheroiccryof"Iwillworkhard
最新回复
(
0
)