📄 exp18_1.cpp
字号:
/*建立一个应用程序,包括数据输入、存盘、读盘、操作数据后存储。通过随机数函数rand()产生20个整数,
逐个将这些数以二进制方式写入文件file.dat中。然后读出这些数,在内存中对它们进行增序排序,再将排序
后的数以文本方式逐个写入file.out文件中。
[程序] 用C++的文件流进行文件管理,用流类的函数进行文件读写。
*/
#include<iostream.h>
#include<math.h>
#include<stdlib.h>
#include<fstream.h>
#include<iomanip.h>
void sort(int [],int);
main(){
fstream dat, out; //定义文件流对象
int i,a[20],b[20];
dat.open("file.dat",ios::binary|ios::out|ios::in);//为读写打开二进制文件
if(!dat){
cout<< ("cannot open file\n");
exit(0);
}
for(i=0;i<20;i++){
a[i]=rand();
dat.write((char*)&a[i],sizeof(int));//将二十个数写入文件
}
dat.seekg(0); //将文件指针移至文件头
for(i=0;i<20;i++){
dat.read((char*)&b[i],sizeof(int));//读出二十个数
}
sort(b,20); //调用排序函数
out.open("file.out",ios::out); //为输出打开文本文件
if(!out){
cout<<"cannot open file\n";
exit(0);
}
for(i=0;i<20;i++){ //将排序后数据写入文本文件
out<<b[i]<<' ';
}
out<<'\n';
for(i=0;i<20;i++) cout<<b[i]<<' ';
cout<<"\n";
out.close(); //关闭文件
dat.close();
return 0;
}
void sort(int x[],int m){ //排序函数
int i,j,k,t;
for(i=0;i<m-1;i++){
k=i;
for(j=i+1;j<m;j++) if(x[j]<x[k]) k=j;
if(k!=i){
t=x[i];x[i]=x[k];x[k]=t;
}
}
}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -