⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 algo1201.cpp

📁 In addition to individual algorithm, Demonstration System is a "data structure" (C language version)
💻 CPP
字号:
Status MergeFile (FILE *f, FILE *g, FILE *h) {  // 算法12.1
  // 由按关键字递增有序的非空顺序文件f和g归并得到新文件h,三个文件均
  // 已打开,其中,f和g为只读文件,文件中各附加一个最大关键字记录,
  // 且g文件中对该记录的操作为插入。h为只写文件
  RcdType fr, gr;
  fread(&fr, sizeof(RcdType), 1, f);
  fread(&gr, sizeof(RcdType), 1, g);
  while (!feof(f) || !feof(g)) {
    if (fr.key < gr.key) {                   // 复制"旧"主文件中记录
      fwrite(&fr, sizeof(RcdType), 1, h);
      /*if (!feof(f))*/ fread(&fr, sizeof(RcdType), 1, f);
    } else if (gr.code=='D' && fr.key==gr.key) {  
      // 删除"旧"主文件中记录,即不复制
      /*if (!feof(f))*/ fread(&fr, sizeof(RcdType), 1, f);
      /*if (!feof(g))*/ fread(&gr, sizeof(RcdType), 1, g);
    } else if (gr.code=='I' && fr.key>gr.key) {   
      // 插入,函数P把gr加工为h的结构
      fwrite(P(gr), sizeof(RcdType), 1, h);
      /*if (!feof(g))*/ fread(&gr, sizeof(RcdType), 1, g);
    } else if (gr.code=='U' && fr.key==gr.key) {  
      // 更改"旧"主文件中记录
      fwrite(Q(fr, gr), sizeof(RcdType), 1, h);  
          // 函数Q将fr和gr归并成一个h结构的记录
      /*if (!feof(f))*/ fread(&fr, sizeof(RcdType), 1, f);
      /*if (!feof(g))*/ fread(&gr, sizeof(RcdType), 1, g);
    } else return ERROR;    // 其它均为出错情况
  }  // while 
  return OK;
} // MergeFile

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -