#include<iostream.h>

#include<stdlib.h>

#include<string.h>

#include<fstream.h>

struct staff{

long staNum;

char staName[500];

long phoNum;

long num;

char staAddr[1000];

}staf,staf1;

void main(){

fstream fstr1,fstr2,fstr,fstrt;

char i,fn1[80],fn2[80],fn[80],fnt[80],*p1,*p2,*p,*pt,str[1000];

//staff staf1;

int a,b;

p1=&fn1[0]; p2=&fn2[0]; p=&fn[0]; pt=&fnt[0];

cout<<"Please input the file name of fn1:\n";

//cin>>p1;

//fstr1.open(p1,ios::binary|ios::in|ios::out);     //1

fstr1.open("E:\\新建文件夹\\新建文件夹\\a.bat",ios::binary|ios::in|ios::out);

if(!p1){ cerr<<"Can't open the file fn1.\n"; return; }

fstr1.seekp(0,ios::end);

cout<<"Please input the number i(Y|y).\n";

cin>>i;

while(i=='Y'||i=='y'){

cout<<"Please input the number staf.\n";

cin>>staf.staNum>>staf.staName>>staf.phoNum>>staf.num>>staf.staAddr;

fstr1.write((char *) &staf,sizeof(staf));    //文件名对象.write函数里的buffer类型只能是(char *),不能是其他类型fstr1.write((int *) &a,sizeof(a));

cout<<"Please input the number i.(Y|y)\n";

cin>>i;  }

cout<<"Please input the file name of fn2:\n";

//cin>>p2;

//fstr2.open(p2,ios::binary|ios::in|ios::out);   //2

fstr2.open("E:\\新建文件夹\\新建文件夹\\b.bat",ios::binary|ios::in|ios::out);

if(!p2){ cerr<<"Can't open the file fn2.\n"; return; }

fstr2.seekp(0,ios::end);

cout<<"Please input the number i.(Y|y)\n";

cin>>i;

while(i=='Y'||i=='y'){

cout<<"Please input the number staf1.\n";

cin>>staf1.staNum>>staf1.staName>>staf1.phoNum>>staf1.num>>staf1.staAddr;

fstr2.write((char *) &staf1,sizeof(staf1));

cout<<"Please input the number i(Y|y).\n"; cin>>i;  }

cout<<"Please input the file name of fn.\n";    //3

//cin>>p;

//fstr.open(p,ios::binary|ios::in|ios::out);

fstr.open("E:\\新建文件夹\\新建文件夹\\file.bat",ios::binary|ios::in|ios::out);

if(!p){ cerr<<"Can't open the file of fn.\n"; return; }

fstr1.seekp(0,ios::end);

long pEnd1=fstr1.tellp();

fstr2.seekp(0,ios::end);

long pEnd2=fstr2.tellp();

fstr1.seekp(0,ios::beg);

fstr2.seekp(0,ios::beg);

while(fstr1.tellp()!=pEnd1&&fstr2.tellp()!=pEnd2){

fstr1.read((char *) &staf,sizeof(staf));

fstr2.read((char *) &staf1,sizeof(staf1));

if(staf.staNum>>staf1.staNum) fstr.write((char *) &staf,sizeof(staf));

else fstr.write((char *) &staf1,sizeof(staf1));

//fstr<<staf1.staNum<<ends<<staf1.staName<<ends<<staf1.phoNum<<ends<<staf1.num<<staf1.staAddr;     }

while(fstr1.tellp()!=pEnd1) fstr.write((char *) &staf,sizeof(staf));

while(fstr2.tellp()!=pEnd2) fstr.write((char *) &staf1,sizeof(staf1));

cout<<"Please input the file name of fn4.\n";    //4

//cin>>pt;

//fstrt.open(pt,ios::in|ios::out);

fstrt.open("E:\\新建文件夹\\新建文件夹\\l.txt",ios::in|ios::out);

if(!pt){ cerr<<"Can't open the file of fn.\n"; return; }

fstr.seekg(0,ios::end);

long pEnd3=fstr.tellg();

fstr.seekg(0,ios::beg);

while(fstr.tellg()!=pEnd3){

fstr.read((char *) &staf,sizeof(staf));

fstrt<<staf.staNum<<ends<<staf.staName<<ends<<staf.phoNum<<ends<<staf.num<<staf.staAddr<<endl;

cout<<staf.staNum<<ends<<staf.staName<<ends<<staf.phoNum<<ends<<staf.num<<staf.staAddr<<endl;

} cout<<endl; fstrt.close();

cout<<"Please input the file name of fn4.\n";    //5

//cin>>pt;

//fstrt.open(pt,ios::in|ios::out);

fstrt.open("E:\\新建文件夹\\新建文件夹\\l.txt",ios::in|ios::out);

if(!pt){ cerr<<"Can't open the file of fn.\n"; return; }

//while(fstrt.tellg()!=ptEnd){ fstrt.getline(fn,800);

//cout<<staf.staNum<<ends<<staf.staName<<ends<<staf.phoNum<<ends<<staf.num<<staf.staAddr<<endl; } //二进制的判断方法

do{ fstrt.getline(str,1000); cout<<str<<endl;  }while(!fstrt.eof());

fstr1.close(); fstr2.close(); fstr.close(); fstrt.close();

} */

C++->10.3.6.设有两个按升序排列的二进制文件a和b,将他们合并成一个新的升序二进制数据文件file。的更多相关文章

  1. 将两个列不同的DataTable合并成一个新的DataTable

    /// <summary>         /// 将两个列不同(结构不同)的DataTable合并成一个新的DataTable         /// </summary> ...

  2. 将两个数组相同index的value合并成一个新的value组成一个新的数组

    将两个数组相同index的value合并成一个新的value组成一个新的数组 前提: 这两个数组的长度相同 生成后的新数组长度也相同 返回值都是对象 把rows对象的key和value弄成两个数组, ...

  3. Java-Runoob-高级教程-实例-字符串:10. Java 实例 - 测试两个字符串区域是否相等-uncheck

    ylbtech-Java-Runoob-高级教程-实例-字符串:10. Java 实例 - 测试两个字符串区域是否相等 1.返回顶部 1. Java 实例 - 测试两个字符串区域是否相等  Java ...

  4. python之最强王者(10)———文件(File)、输入输出的基本操作

    1. Python 文件I/O 本章只讲述所有基本的的I/O函数,更多函数请参考Python标准文档. 2.打印到屏幕 最简单的输出方法是用print语句,你可以给它传递零个或多个用逗号隔开的表达式. ...

  5. ORA-01578: ORACLE 数据块损坏 (文件号 10, 块号 57896)ORA-01110: 数据文件 10: '/data/oradata/prod35.dbf'

    https://community.oracle.com/thread/3540795 概述 ------------- 数据库坏块(corruption) 的类型可以按照坏块所属对象的不同,分为用户 ...

  6. delphi 创建DBASE和FOXPRO两类DBF数据文件的差异

    delphi 创建DBASE和FOXPRO两类DBF数据文件的差异,主要有几点: 1.创建方法不同 DBASE的创建方法: Self.Table1.Close; Self.Table1.Active ...

  7. 如何定义让两个div横向排列

    方法一: 一般情况,默认的div是写一个换一行,那么如何定义两个div横向排列而不换行呢? div默认的display属性是block.所以每一个div都是新的一行,现在把display换成inlin ...

  8. 有两个序列A和B,A=(a1,a2,...,ak),B=(b1,b2,...,bk),A和B都按升序排列。对于1<=i,j<=k,求k个最小的(ai+bj)。要求算法尽量高效。

    有两个序列A和B,A=(a1,a2,...,ak),B=(b1,b2,...,bk),A和B都按升序排列.对于1<=i,j<=k,求k个最小的(ai+bj).要求算法尽量高效. int * ...

  9. python将两个数组合并成一个数组的两种方法的代码

    内容过程中,把写内容过程中常用的内容收藏起来,下面的资料是关于python将两个数组合并成一个数组的两种方法的内容,希望能对小伙伴们有帮助. c1 = ["Red","G ...

随机推荐

  1. HDU_4403

    http://acm.hdu.edu.cn/showproblem.php?pid=4403 数值不大,暴力枚举,枚举每一种划分,然后枚举每一种等号位置. #include<iostream&g ...

  2. 关于Android的hellowrd中出现的r文件错误

    当你的androidAPI 由2.1版本更换成2.2版本时:res/vavlues/styles.xml中使用的android:WindowTitle会报以下异常,error: Error retri ...

  3. 使用canvas制作五子棋游戏

    要制作JS五子棋的话我们可以一开始来理清一下思路,这样对我们后来的编程是有好处的 1.棋盘使用canvas制作.canvas用来做这种不用太过复杂的图形的时候是很有用处的,下图是我制作的一个五子棋棋盘 ...

  4. learn about sqlserver partitition and partition table --- add or remove table partitions

    demo/* add partitions */ alter database xxx add filegroup FG_=fff_201708;alter database xxx add file ...

  5. ## springboot 下策略模式的简单使用

    1.灵魂三问 接手前人(已跑路)项目快乐否? 前人项目不写注释懵逼否? 一个方法中一堆if/else,且业务判断条件用简单数字(或英文字母),不带注释,想打人否?     所以,对于上述三个问题,我写 ...

  6. javascript A*算法 寻路算法 获取最短路径算法

    //A算法 自动寻路 路径 class GetAutoPath{ constructor(id, map, sPos, ePos, mapArr){ //this.type = id.type; th ...

  7. 20191230--python学习第一天(补)

    1.py第一个脚本 打开电脑终端,功能键+R 输入命令:解释器路径+脚本路径(建议.py后缀) 2.编码 (1)初始编码 ascii,英文,8为表示一个东西,2**8  8位 = 1字节 unicod ...

  8. React中setState注意事项

    setState是一个异步函数,异步获取数据 学习react在使用ref和setState操作DOM时会遇到的问题: ref获取ul结点元素 错误写法:得到的ul长度总是上一次输入后的长度 结果: 正 ...

  9. Java的七大排序

    一.各个算法的时间复杂度 二,具体实现 1.直接选择排序 基本思想:在长度为n的序列中,第一次遍历找到该序列的最小值,替换掉第一个元素,接着从第二个元素开始遍历,找到剩余序列中的最小值,替换掉第二个元 ...

  10. codewars--js--RGB To Hex Conversion

    问题描述: The rgb() method is incomplete. Complete the method so that passing in RGB decimal values will ...