服务器之家

服务器之家 > 正文

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

时间:2021-04-13 15:32     来源/作者:daisy

功能介绍

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

正常运行要求:

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

运行结果

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

data.txt:

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

obj.txt:

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

完整代码

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

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
#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语言的朋友们很有帮助的。

相关文章

热门资讯

2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全
2020微信伤感网名听哭了 让对方看到心疼的伤感网名大全 2019-12-26
yue是什么意思 网络流行语yue了是什么梗
yue是什么意思 网络流行语yue了是什么梗 2020-10-11
背刺什么意思 网络词语背刺是什么梗
背刺什么意思 网络词语背刺是什么梗 2020-05-22
Intellij idea2020永久破解,亲测可用!!!
Intellij idea2020永久破解,亲测可用!!! 2020-07-29
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总
苹果12mini价格表官网报价 iPhone12mini全版本价格汇总 2020-11-13
返回顶部