服务器之家:专注于服务器技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C/C++ - 用C语言实现从文本文件中读取数据后进行排序的功能

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

2021-04-13 15:32daisy C/C++

这是一个十分可靠的程序,这个程序的查错能力非常强悍。程序包含了文件操作,归并排序和字符串输入等多种技术。对大家学习C语言很有帮助,有需要的一起来看看。

功能介绍

程序的功能是从外部读取一个包括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语言的朋友们很有帮助的。

延伸 · 阅读

精彩推荐