• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

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

c语言 搞代码 4年前 (2022-01-06) 27次浏览 已收录 0个评论

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

功能介绍

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

正常运行要求:

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

运行结果

data.txt:

obj.txt:

完整代码

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

 #include #include #include /*============================= 制作于: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_FA来源gao($daima.com搞@代@#码(网ILURE); } 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){ 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] 

总结

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

以上就是用C语言实现从文本文件中读取数据后进行排序的功能的详细内容,更多请关注gaodaima搞代码网其它相关文章!


搞代码网(gaodaima.com)提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发送到邮箱[email protected],我们会在看到邮件的第一时间内为您处理,或直接联系QQ:872152909。本网站采用BY-NC-SA协议进行授权
转载请注明原文链接:用C语言实现从文本文件中读取数据后进行排序的功能

喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址