用C語(yǔ)言實(shí)現(xiàn)從文本文件中讀取數(shù)據(jù)后進(jìn)行排序的功能
功能介紹
程序的功能是從外部讀取一個(gè)包括int型數(shù)據(jù)的文本文件,然后將它保存到內(nèi)部臨時(shí)數(shù)組,對(duì)數(shù)組進(jìn)行排序后,以文本形式輸出到指定的文件上。因?yàn)槭莍nt類型的數(shù)據(jù),沒(méi)有很嚴(yán)重的損失精度的問(wèn)題。
正常運(yùn)行要求:
包括數(shù)據(jù)的源文件內(nèi)不能包括其他任何除數(shù)字和空白字符(空格,制表符,換行符)之外的任何字符,源文件最開(kāi)始必須是數(shù)字字符,要保證源文件的數(shù)據(jù)計(jì)數(shù)正確。同時(shí)保證文件名有效。
運(yùn)行結(jié)果

data.txt:

obj.txt:

完整代碼
警告:版權(quán)所有,謹(jǐn)供參考!
#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目標(biāo)文件
int * ptr;//臨時(shí)數(shù)組
int i, n; //n表示元素個(gè)數(shù)
char fname[ST]; //臨時(shí)存儲(chǔ)字符串
printf("請(qǐng)輸入元素個(gè)數(shù):");
while( scanf("%d", &n) != 1 || n <= 0 ){
printf("輸入錯(cuò)誤,請(qǐng)重新輸入!\n");
while(getchar() != '\n')
continue;
}
while(getchar() != '\n')
continue;
ptr = (int *)malloc( (size_t)n * sizeof(int) ); //申請(qǐng)動(dòng)態(tài)數(shù)組//////
if(ptr == NULL){
fprintf(stderr, "FAIL TO ASK FOR MEMORY SPACE\n");
exit(EXIT_FAILURE);
}
printf("請(qǐng)輸入原文件名:");
if( s_gets(fname, ST) == NULL ){
fprintf(stderr, "Fail to get a string\n");
exit(EXIT_FAILURE);
}
sor = fopen(fname, "r"); //打開(kāi)包含數(shù)據(jù)的源文件
if(sor == NULL){
fprintf(stderr, "Fail to open the source file\n");
exit(EXIT_FAILURE);
}
for(i = 0; i < n; i++) //獲取數(shù)據(jù)到動(dòng)態(tài)數(shù)組
if( fscanf(sor, "%d", &ptr[i]) != 1 ){
fprintf(stderr, "Fail to get the data\n");
exit(EXIT_FAILURE);
}
mergesort(ptr, n); //排序
printf("請(qǐng)輸入要保存數(shù)據(jù)的文件名:");
if( s_gets(fname, ST) == NULL ){
fprintf(stderr, "Fail to get a string\n");
exit(EXIT_FAILURE);
}
dest = fopen(fname, "w"); //打開(kāi)目標(biāo)文件
if(dest == NULL){
fprintf(stderr, "Fail to open the destination file\n");
exit(EXIT_FAILURE);
}
for(i = 0; i < n; i++){ //輸出數(shù)據(jù)到目標(biāo)文件
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個(gè)就換行
if( fprintf(dest, "\n") < 0 ){
fprintf(stderr, "Fail to save the data\n");
exit(EXIT_FAILURE);
}
}
}
if( fclose(sor) != 0 ){ //關(guān)閉源文件
fprintf(stderr, "Fail to close the source file\n");
exit(EXIT_FAILURE);
}
if( fclose(dest) != 0 ){ //關(guān)閉目標(biāo)文件
fprintf(stderr, "Fail to close the destination file\n");
exit(EXIT_FAILURE);
}
free(ptr); //釋放內(nèi)存
printf("成功完成!\n請(qǐng)按任意鍵繼續(xù)^ ^\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); //左子數(shù)組排序
_mergesort(ar, mid + 1, end, temp); //右子數(shù)組排序
merge(ar, start, mid, end, temp); //合并子數(shù)組
}
}
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') //如果沒(méi)有到輸入字符串結(jié)束
i++; //遞增
if(st[i] == '\n') //如果字符串最后一個(gè)字符是'\n'
st[i] = '\0'; //把它變成'\0'
else //否則緩沖區(qū)內(nèi)還有一部分超出讀取范圍的字符沒(méi)有被讀取
while(getchar() != '\n') //把這些字符讀取完(清空緩沖區(qū))
continue;
}
return re;
}
總結(jié)
以上就是用C語(yǔ)言實(shí)現(xiàn)從文本文件中讀取數(shù)據(jù)后進(jìn)行排序功能的全部?jī)?nèi)容,閱讀這篇文章后,大家自己進(jìn)行調(diào)試運(yùn)行,相信會(huì)對(duì)于學(xué)習(xí)C語(yǔ)言的朋友們很有幫助的。
- c語(yǔ)言冒泡排序法代碼
- C語(yǔ)言實(shí)現(xiàn)排序算法之歸并排序詳解
- c語(yǔ)言實(shí)現(xiàn)冒泡排序、希爾排序等多種算法示例
- c語(yǔ)言快速排序算法示例代碼分享
- c語(yǔ)言合并兩個(gè)已排序數(shù)組的示例(c語(yǔ)言數(shù)組排序)
- 用c語(yǔ)言實(shí)現(xiàn)冒泡排序,選擇排序,快速排序
- 合并排序(C語(yǔ)言實(shí)現(xiàn))
- C語(yǔ)言排序算法之插入排序
- C語(yǔ)言實(shí)現(xiàn)選擇排序、冒泡排序和快速排序的代碼示例
- C語(yǔ)言實(shí)現(xiàn)3個(gè)數(shù)從小到大排序/輸出的方法示例
相關(guān)文章
深入解析C語(yǔ)言中的內(nèi)存分配相關(guān)問(wèn)題
這篇文章主要深入地介紹了C語(yǔ)言中的內(nèi)存分配,C語(yǔ)言編程中的內(nèi)存泄漏問(wèn)題一直以來(lái)都是C編程中的一大棘手問(wèn)題,本文從malloc和指針等方面對(duì)C內(nèi)存進(jìn)行了深層次講解,強(qiáng)烈推薦!需要的朋友可以參考下2015-08-08
C++開(kāi)發(fā)之CRC校驗(yàn)實(shí)例詳解
這篇文章主要介紹了C++開(kāi)發(fā)之CRC校驗(yàn)實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下2017-07-07
深入解析C++的循環(huán)鏈表與雙向鏈表設(shè)計(jì)的API實(shí)現(xiàn)
這篇文章主要介紹了C++的循環(huán)鏈表與雙向鏈表設(shè)計(jì)的API實(shí)現(xiàn),文中的示例對(duì)于鏈表結(jié)點(diǎn)的操作起到了很好的說(shuō)明作用,需要的朋友可以參考下2016-03-03
C++ EasyX學(xué)習(xí)之鼠標(biāo)操作詳解
EasyX是針對(duì)C/C++的圖形庫(kù),可以幫助使用C/C++語(yǔ)言的程序員快速上手圖形和游戲編程。本文將為大家詳細(xì)講講EasyX的鼠標(biāo)操作,需要的可以參考一下2022-07-07
C語(yǔ)言實(shí)現(xiàn)奇數(shù)階魔方陣的方法
這篇文章主要介紹了C語(yǔ)言實(shí)現(xiàn)奇數(shù)階魔方陣的方法,涉及數(shù)組及相關(guān)數(shù)學(xué)函數(shù)的使用技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-02-02

