用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ù)字和空白字符(空格,制表符,換行符)之外的任何字符,源文件最開始必須是數(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"); //打開包含數(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"); //打開目標(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++類結(jié)構(gòu)體與json相互轉(zhuǎn)換
這篇文章主要介紹的是C++類結(jié)構(gòu)體與json相互轉(zhuǎn)換,json字符串一般使用的是開源的類庫(kù)Newtonsoft.Json,方法十分簡(jiǎn)潔,下面就隨小編一起看下面文章內(nèi)容吧2021-09-09
Python與C++ 遍歷文件夾下的所有圖片實(shí)現(xiàn)代碼
這篇文章主要介紹了 Python與C++ 遍歷文件夾下的所有圖片實(shí)現(xiàn)代碼的相關(guān)資料,需要的朋友可以參考下2017-06-06
C++實(shí)現(xiàn)LeetCode(72.編輯距離)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(72.編輯距離),本篇文章通過(guò)簡(jiǎn)要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07
C++日期類計(jì)算器的模擬實(shí)現(xiàn)舉例詳解
兩個(gè)日期之間相隔天數(shù)的計(jì)算網(wǎng)上有許多的軟件,這里主要介紹如何使用C/C++語(yǔ)言來(lái)完成這樣的功能,下面這篇文章主要給大家介紹了關(guān)于C++日期類計(jì)算器的模擬實(shí)現(xiàn),需要的朋友可以參考下2023-04-04
C++的動(dòng)態(tài)內(nèi)存管理你真的了解嗎
這篇文章主要為大家詳細(xì)介紹了C++的動(dòng)態(tài)內(nèi)存管理,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助2022-02-02
C語(yǔ)言實(shí)現(xiàn)通訊錄系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)通訊錄系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-02-02
C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)易文本編譯器
這篇文章主要為大家詳細(xì)介紹了C語(yǔ)言實(shí)現(xiàn)簡(jiǎn)易文本編譯器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-05-05

