当前位置:   article > 正文

两个文件分别保存若干学生数据(包括学号、姓名和成绩),且按成绩升序排列。编写程序,把两个文件归并到第三个文件,使第三个文件中的学生数据也按成绩升序排列。_建立文件文本,存储若干学生成绩记录,包含姓名,学号,成绩,文件名为text3.txt,

建立文件文本,存储若干学生成绩记录,包含姓名,学号,成绩,文件名为text3.txt,

一、题目

程序功能:两个非空二进制文件 a1.dat 和 a2.dat,分别保存若干学生数据(包括学号、姓名和成绩),且按成绩升序排列。编写程序,把 a1.dat 和 a2.dat 两个文件归并到 a3.dat 文件,使得 a3.dat 文件中的学生数据也按成绩升序排列。要求如下:

① 定义 mergeFile()函数:将两个二进制文件归并成一个按成绩升序排列的新文件。

② 定义 main()函数:先打开二进制文件 a1.dat、a2.dat、a3.dat,再调用 mergeFile()函数将 a1.dat、a2.dat 两个文件归并到按成绩升序排列的 a3.dat 文件,最后输出 a3.dat 文件内容。

二、程序清单

  1. #include<stdio.h>
  2. #include<stdlib.h>
  3. typedef struct student {
  4. char id[30];//学号
  5. char name[20];//姓名
  6. char score[10];//成绩
  7. struct student* next;
  8. };
  9. student* ReadFile(FILE* pfile)//读取文件信息并存入链表中并返回该链表
  10. {
  11. student* L = (student*)malloc(sizeof(student));
  12. student* r = L;
  13. while (!feof(pfile))
  14. {
  15. student* p = (student*)malloc(sizeof(student));
  16. fscanf(pfile, "%s %s %s\n", &p->id, p->name, p->score);
  17. r->next = p;
  18. r = r->next;
  19. }
  20. r->next = NULL;
  21. return L;
  22. }
  23. student* mergeFile(FILE* p1, FILE* p2, FILE* p3)//将两个二进制文件归并成一个按成绩升序排列的新文件
  24. {
  25. student* L1 = ReadFile(p1);//调用函数
  26. student* L2 = ReadFile(p2);//调用函数
  27. student* r1 = L1->next;
  28. student* r2 = L2->next;
  29. student* L3 = (student*)malloc(sizeof(student));
  30. student* r3 = L3;
  31. while (r1 && r2)//若两链表均未结尾,则进入循环
  32. {
  33. if (atoi(r1->score) >= atoi(r2->score))//将成绩较低的学生信息链入新链表的结尾
  34. {
  35. fprintf(p3, "%s %s %s\n", r2->id, r2->name,r2->score);
  36. r3->next = r2;
  37. r3 = r3->next;
  38. r2 = r2->next;
  39. }
  40. else
  41. {
  42. fprintf(p3, "%s %s %s\n", r1->id, r1->name, r1->score);
  43. r3->next = r1;
  44. r3 = r3->next;
  45. r1 = r1->next;
  46. }
  47. }
  48. if (r1)//将较长的链表中未接入的部分接入新链表的末尾
  49. {
  50. while (r1)
  51. {
  52. atoi(r1->score);
  53. fprintf(p3, "%s %s %s\n", r1->id, r1->name, r1->score);
  54. r3->next = r1;
  55. r3 = r3->next;
  56. r1 = r1->next;
  57. }
  58. }
  59. else
  60. while (r2)
  61. {
  62. atoi(r2->score);
  63. fprintf(p3, "%s %s %s\n", r2->id, r2->name, r2->score);
  64. r3->next = r2;
  65. r3 = r3->next;
  66. r2 = r2->next;
  67. }
  68. return L3;//返回升序排列后的链表头指针
  69. }
  70. void PrintList(student* L)//输出单链表内容
  71. {
  72. student* p = L->next;
  73. printf("学号\t姓名\t成绩\n");
  74. while (p)
  75. {
  76. printf("%s\t%s\t%s\n", p->id, p->name, p->score);
  77. p = p->next;
  78. }
  79. }
  80. int main()
  81. {
  82. FILE* p1;
  83. FILE* p2;
  84. FILE* p3;
  85. if ((p1 = fopen("a1.dat", "rb")) == NULL)//读模式
  86. {
  87. printf("文件a1.dat打开失败!");
  88. exit(0);
  89. }
  90. if ((p2 = fopen("a2.dat", "rb")) == NULL)//读模式
  91. {
  92. printf("文件a2.dat打开失败!");
  93. exit(0);
  94. }
  95. if ((p3 = fopen("a3.dat", "wb")) == NULL)//写模式
  96. {
  97. printf("文件a3.dat打开失败!");
  98. exit(0);
  99. }
  100. PrintList(mergeFile(p1, p2, p3));//调用函数
  101. if (fclose(p1))
  102. {
  103. printf("不能正常关闭文件a1.dat!");
  104. exit(0);
  105. }
  106. if (fclose(p2))
  107. {
  108. printf("不能正常关闭文件a2.dat!");
  109. exit(0);
  110. }
  111. if (fclose(p3))
  112. {
  113. printf("不能正常关闭文件a3.dat!");
  114. exit(0);
  115. }
  116. return 0;
  117. }

三、运行结果

 

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/繁依Fanyi0/article/detail/608854
推荐阅读
相关标签
  

闽ICP备14008679号