当前位置: 首页 > 编程笔记 >

用C语言实现从文本文件中读取数据后进行排序的功能

蒋哲
2023-03-14
本文向大家介绍用C语言实现从文本文件中读取数据后进行排序的功能,包括了用C语言实现从文本文件中读取数据后进行排序的功能的使用技巧和注意事项,需要的朋友参考一下

功能介绍

程序的功能是从外部读取一个包括int型数据的文本文件,然后将它保存到内部临时数组,对数组进行排序后,以文本形式输出到指定的文件上。因为是int类型的数据,没有很严重的损失精度的问题。

正常运行要求:

包括数据的源文件内不能包括其他任何除数字和空白字符(空格,制表符,换行符)之外的任何字符,源文件最开始必须是数字字符,要保证源文件的数据计数正确。同时保证文件名有效。

运行结果

data.txt:

obj.txt:

完整代码

警告:版权所有,谨供参考!

#include <stdio.h>
#include <stdlib.h>
#include <conio.h>

/*=============================
  制作于:Aug 16, 2016
  by QQ:1729403632
===============================*/

#define ST 64 //字符串大小

void mergesort(int *, int);
void _mergesort(int *, int, int, int *);
void merge(int *, int, int, int, int *);
char * s_gets(char *, int);

int main(int argc, char * argv[]){
  FILE * sor, * dest; //sor源文件 dest目标文件
  int * ptr;//临时数组
  int i, n; //n表示元素个数
  char fname[ST]; //临时存储字符串

  printf("请输入元素个数:");
  while( scanf("%d", &n) != 1 || n <= 0 ){
    printf("输入错误,请重新输入!\n");
    while(getchar() != '\n')
      continue;
  }
  while(getchar() != '\n')
      continue;

  ptr = (int *)malloc( (size_t)n * sizeof(int) ); //申请动态数组//////
  if(ptr == NULL){
    fprintf(stderr, "FAIL TO ASK FOR MEMORY SPACE\n");
    exit(EXIT_FAILURE);
  }

  printf("请输入原文件名:");
  if( s_gets(fname, ST) == NULL ){
    fprintf(stderr, "Fail to get a string\n");
    exit(EXIT_FAILURE);
  }

  sor = fopen(fname, "r"); //打开包含数据的源文件
  if(sor == NULL){
    fprintf(stderr, "Fail to open the source file\n");
    exit(EXIT_FAILURE);
  }

  for(i = 0; i < n; i++) //获取数据到动态数组
    if( fscanf(sor, "%d", &ptr[i]) != 1 ){
      fprintf(stderr, "Fail to get the data\n");
      exit(EXIT_FAILURE);
    }

  mergesort(ptr, n); //排序

  printf("请输入要保存数据的文件名:");
  if( s_gets(fname, ST) == NULL ){
    fprintf(stderr, "Fail to get a string\n");
    exit(EXIT_FAILURE);
  }

  dest = fopen(fname, "w"); //打开目标文件
  if(dest == NULL){
    fprintf(stderr, "Fail to open the destination file\n");
    exit(EXIT_FAILURE);
  }

  for(i = 0; i < n; i++){ //输出数据到目标文件
    if( fprintf(dest, "%d\t", ptr[i]) < 0 ){
      fprintf(stderr, "Fail to save the data\n");
      exit(EXIT_FAILURE);
    }
    if( ((i + 1) % 10) == 0){ //如果写满10个就换行
      if( fprintf(dest, "\n") < 0 ){
        fprintf(stderr, "Fail to save the data\n");
        exit(EXIT_FAILURE);
      }
    }
  }

  if( fclose(sor) != 0 ){ //关闭源文件
    fprintf(stderr, "Fail to close the source file\n");
    exit(EXIT_FAILURE);
  }
  if( fclose(dest) != 0 ){ //关闭目标文件
    fprintf(stderr, "Fail to close the destination file\n");
    exit(EXIT_FAILURE);
  }
  free(ptr); //释放内存

  printf("成功完成!\n请按任意键继续^ ^\b\b");

  getch();
  return 0;
}

void mergesort(int * ar, int size){
  if(size > 0){
    int * temp;
    temp = (int *)malloc( (size_t)size * sizeof(int) ); /////
    if(temp == NULL){
      fprintf(stderr, "Fail to ask for MEMORY SPACE\n");
      exit(EXIT_FAILURE);
    }
    _mergesort(ar, 0, size - 1, temp); //归并排序
    free(temp);
  }
}

void _mergesort(int * ar, int start, int end, int * temp){
  if(start < end){
    int mid = (start + end) / 2;
    _mergesort(ar, start, mid, temp);  //左子数组排序
    _mergesort(ar, mid + 1, end, temp);  //右子数组排序
    merge(ar, start, mid, end, temp);  //合并子数组
  }
}

void merge(int * ar, int p, int q, int r, int * temp){
  int i = p, j = q + 1, k = 0;
  while(i <= q && j <= r){
    if(ar[i] < ar[j])
      temp[k++] = ar[i++];
    else
      temp[k++] = ar[j++];
  }
  while(i <= q)  //如果序列[i...q]存在,追加
    temp[k++] = ar[i++];
  while(j <= r)  //如果序列[j...r]存在,追加
    temp[k++] = ar[j++];

  for(k = 0; k <= (r - p); k++)
    ar[p + k] = temp[k];
}

char * s_gets(char * st, int size){
  char * re;
  int i = 0;

  re = fgets(st, size, stdin);
  if(re){
    while(st[i] != '\n' && st[i] != '\0') //如果没有到输入字符串结束
      i++;  //递增
    if(st[i] == '\n') //如果字符串最后一个字符是'\n'
      st[i] = '\0'; //把它变成'\0'
    else //否则缓冲区内还有一部分超出读取范围的字符没有被读取
      while(getchar() != '\n') //把这些字符读取完(清空缓冲区)
        continue;
  }

  return re;
}

总结

以上就是用C语言实现从文本文件中读取数据后进行排序功能的全部内容,阅读这篇文章后,大家自己进行调试运行,相信会对于学习C语言的朋友们很有帮助的。

 类似资料:
  • 问题 你要写C扩展来读取来自任何Python类文件对象中的数据(比如普通文件、StringIO对象等)。 解决方案 要读取一个类文件对象的数据,你需要重复调用 read() 方法,然后正确的解码获得的数据。 下面是一个C扩展函数例子,仅仅只是读取一个类文件对象中的所有数据并将其输出到标准输出: #define CHUNK_SIZE 8192 /* Consume a "file-like" ob

  • 我正在尝试使用TextScan从文本文件中读取数据。textfile由3个空格分隔,有100行数据和9列。我可以让它返回我认为是100×1的矩阵。我想知道如何得到返回矩阵100×9的代码。下面是我使用的代码... 正如您所看到的,当我访问数据{5}时,我得到了一些接近我想要的东西。我的最终目标是创建一个包含1-8列的矩阵,然后创建一个包含9行的列矩阵。下面是如何在文本文件中格式化数据。第1列之前有

  • 我正在尝试排序的键(优先数,int数)从最高到最低的链表,与数据从文本文件。我正在埋头插入项目并对它们进行排序。这是我的文本文件。 我的工作66 垃圾17 资金25 重要96 生命99 Moreutn 28 工作69 转让44 这是我的链表类 } 下面是我的节点类: 下面是我的数据类: 从链表类运行时的当前输出: 我的insert方法总是在第一个if语句处停止,而从不继续运行。我不知道怎么修好它。

  • 本文向大家介绍C语言实现排雷游戏(多文件),包括了C语言实现排雷游戏(多文件)的使用技巧和注意事项,需要的朋友参考一下 本文实例为大家分享了C语言实现排雷游戏的具体代码,供大家参考,具体内容如下 游戏功能: ①打印雷盘 ②随机布雷 ③第一踩雷不死(重新布雷) ④扩展式扫雷 ⑤计算周围雷的个数 代码关键点: ①玩游戏的雷盘比实际定义的数组小。 ②memset初始化数组(以字节为单位初始化)。 ③ra

  • 本文向大家介绍易语言读取文本行数的方法,包括了易语言读取文本行数的方法的使用技巧和注意事项,需要的朋友参考一下 易语言 取文本行数教程 本教材使用易语言自带支持库中的“分割文本”功能取出文本行数 1、新建一个窗口程序 添加一个编辑框组件 和按钮组件 2、在工作夹中把编辑框的 是否允许多行选择“真”和滚动条选择”纵向滚动条“ 3、进入代码编辑窗口 写入一下代码 4、调试运行一下 信息框会显示出编辑框

  • 本文向大家介绍C语言对磁盘文件进行快速排序简单实例,包括了C语言对磁盘文件进行快速排序简单实例的使用技巧和注意事项,需要的朋友参考一下 C语言对磁盘文件进行快速排序简单实例 快速排序(quick sort)是由C.A.R.Hoare发明并命名的,这种排序被认为是目前最好的一种排序算法。快速排序基于交换排序,与同样的基于交换排序的冒泡排序法相比,其效果非常明显。 它的基本思想是:通过一趟排序将要排序