首页
外语
计算机
考研
公务员
职业资格
财经
工程
司法
医学
专升本
自考
实用职业技能
登录
计算机
请打开考生文件夹下的解决方案文件proj3,其中声明的DataList类,是一个用于表示数据表的类。sort成员函数的功能是将当前数据表中的元素升序排列。请编写这个sort函数。程序的正确输出应为: 排序前:7,1,3,11,6,9,12,10,8
请打开考生文件夹下的解决方案文件proj3,其中声明的DataList类,是一个用于表示数据表的类。sort成员函数的功能是将当前数据表中的元素升序排列。请编写这个sort函数。程序的正确输出应为: 排序前:7,1,3,11,6,9,12,10,8
admin
2020-04-07
34
问题
请打开考生文件夹下的解决方案文件proj3,其中声明的DataList类,是一个用于表示数据表的类。sort成员函数的功能是将当前数据表中的元素升序排列。请编写这个sort函数。程序的正确输出应为:
排序前:7,1,3,11,6,9,12,10,8,4,5,2
排序后:1,2,3,4,5,6,7,8,9,10,11,12
要求:
补充编制的内容写在“//******** 333 ********”与“//****** 666 ******”两行之间。不得修改程序的其他部分。
注意:程序最后将结果输出到文件out.dat中。输出函数writeToFile已经编译为obj文件,并且在本程序调用。
//DataList.h
#include<iostream>
using namespace std;
class DataList{//数据表类
int len;
double*d;
public:
DataLlst(int len,double data[]=NULL);
~DataList(){delete[]d;}
int length()const{return len;)
//数据表长度(即数据元素的个数)
double getElement (int i)consL{return d
;}
void sort();//数据表排序
void show()const;//显示数据表
};
void writeToFile(char *, constDataList&);
//main.cpp
#include"DataList.h"
DataList::DataList(int len,double data[]):len(fen)(
d=new double[len];
for(int i=0;i<len; i++)
d
=(data==NULL?0.0:data
);
}
void DataList::sort(){//数据表排序
//******** 333 ********
//******** 666 ********
}
void DataList::show()const{
//显示数据表
for(int i=0; i<len一1;i++)tout<<d
<<",";
couL<<d[len—1]<<endl;
}
int main(){
double s[]={7,1,3,11,6,9,12,10,8,4,5,2};
DaLaList list(12,s);
cout<<"排序前:";
list.show();
list.soft();
cout<<endl<<”排序后:”;
list.show();
writeToFile("",list);
return 0;
}
选项
答案
for(int 1 =0;i<len; ++1) //从头遍历数组d for(int j =i;j <len; ++j) //从i+1处遍历数组d if(d[i]>d[j]) //d[i]和d[j]比较人,如果大于,就d[i]和d[j]做换 { int temp=d[i]; //把临时整型变量temp赋值为d[i] d[i]=d[j]; //把d[j]赋值给d[i] d[j]=temp; //把temp值赋给d[j] }
解析
本题使用最简单的冒泡排序算法,首先明确要排序的动态数组d,其长度为len,在此可以使用两个下标i和j相比较,当d
>d[j]时,数组内的值利用中间变量temp进行交换。
转载请注明原文地址:https://kaotiyun.com/show/Nw8p777K
本试题收录于:
二级C题库NCRE全国计算机二级分类
0
二级C
NCRE全国计算机二级
相关试题推荐
使用如setw()的操纵符对数据进行格式输出时,应包含()文件。
要建立文件流并打开当前目录下的文件file.dat用于输入,下列语句中错误的是
下列程序的输出结果是#include<iostream.h>intmin(inta,intb){if(a<b)returna;elsereturnb;return0;
以下不正确的定义浯句是
程序设计语言的工程特性之一为()。
从工程管理的角度来看,软件设计分两步来完成。首先是概要设计,然后是【】。
下列程序输出的结果是()。#include<stdio.h>sub1(chara,charb){charc;c=a;a=b;b=c:}sub2(char*a,charb){charc;c=*a;”a=b:b=c
虚函数必须是类的()。
以下C++语言中用于单行注释的是
已知基类Employee只有一个构造函数,其定义如下:Employee::Employee(intn):id(n){}Manager是Employee的派生类,则F列对Manager的构造函数的定义中,正确的是
随机试题
在正常生产情况下,单件小批量生产时,铸件公称尺寸为()时,其公差等级提高2级。
被誉为“儿科之圣”的古代医家是( )。
下列常用于液体药剂防腐的是()
裱糊基层对于木材基层的含水率不得大于()。
海关发现进出口货物报关单需要进行修改或者撤销的,收发货人或其代理人应当提交进出口货物报关单修改/撤销申请表。
在讲数字“2”时。有小朋友大声说。这是一条蛇,老师讲讲蛇吧,你怎么办?
关于搜查,下列哪一说法是不正确的?()
不动产所有人出卖其不动产时,下列不享有优先购买权的是()。
Beguninthelate1960sbyPentagonweaponsresearchersasasystemforeasingcommunicationbetweencomputersindisparateelec
Takingyourdogonvacationmayhavebeen【B1】______adecadeago,buttodayit’sflee.【B2】______thepet-friendlyhotel,whe
最新回复
(
0
)