欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

用C語言實現(xiàn)從文本文件中讀取數(shù)據(jù)后進行排序的功能

 更新時間:2016年08月17日 10:31:37   投稿:daisy  
這是一個十分可靠的程序,這個程序的查錯能力非常強悍。程序包含了文件操作,歸并排序和字符串輸入等多種技術。對大家學習C語言很有幫助,有需要的一起來看看。

功能介紹

程序的功能是從外部讀取一個包括int型數(shù)據(jù)的文本文件,然后將它保存到內(nèi)部臨時數(shù)組,對數(shù)組進行排序后,以文本形式輸出到指定的文件上。因為是int類型的數(shù)據(jù),沒有很嚴重的損失精度的問題。

正常運行要求:

包括數(shù)據(jù)的源文件內(nèi)不能包括其他任何除數(shù)字和空白字符(空格,制表符,換行符)之外的任何字符,源文件最開始必須是數(shù)字字符,要保證源文件的數(shù)據(jù)計數(shù)正確。同時保證文件名有效。

運行結(jié)果

data.txt:

obj.txt:

完整代碼

警告:版權(quá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目標文件
  int * ptr;//臨時數(shù)組
  int i, n; //n表示元素個數(shù)
  char fname[ST]; //臨時存儲字符串

  printf("請輸入元素個數(shù):");
  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) ); //申請動態(tài)數(shù)組//////
  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"); //打開包含數(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ù)到動態(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("請輸入要保存數(shù)據(jù)的文件名:");
  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++){ //輸出數(shù)據(jù)到目標文件
    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); //釋放內(nèi)存

  printf("成功完成!\n請按任意鍵繼續(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') //如果沒有到輸入字符串結(jié)束
      i++;  //遞增
    if(st[i] == '\n') //如果字符串最后一個字符是'\n'
      st[i] = '\0'; //把它變成'\0'
    else //否則緩沖區(qū)內(nèi)還有一部分超出讀取范圍的字符沒有被讀取
      while(getchar() != '\n') //把這些字符讀取完(清空緩沖區(qū))
        continue;
  }

  return re;
}

總結(jié)

以上就是用C語言實現(xiàn)從文本文件中讀取數(shù)據(jù)后進行排序功能的全部內(nèi)容,閱讀這篇文章后,大家自己進行調(diào)試運行,相信會對于學習C語言的朋友們很有幫助的。

相關文章

  • C語言異常處理機制案例講解

    C語言異常處理機制案例講解

    這篇文章主要介紹了C語言異常處理機制案例講解,本文講解了異常處理機制所用的函數(shù)和具體的代碼實現(xiàn)等,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • C++類結(jié)構(gòu)體與json相互轉(zhuǎn)換

    C++類結(jié)構(gòu)體與json相互轉(zhuǎn)換

    這篇文章主要介紹的是C++類結(jié)構(gòu)體與json相互轉(zhuǎn)換,json字符串一般使用的是開源的類庫Newtonsoft.Json,方法十分簡潔,下面就隨小編一起看下面文章內(nèi)容吧
    2021-09-09
  • Python與C++ 遍歷文件夾下的所有圖片實現(xiàn)代碼

    Python與C++ 遍歷文件夾下的所有圖片實現(xiàn)代碼

    這篇文章主要介紹了 Python與C++ 遍歷文件夾下的所有圖片實現(xiàn)代碼的相關資料,需要的朋友可以參考下
    2017-06-06
  • c/c++中變量的聲明和定義深入解析

    c/c++中變量的聲明和定義深入解析

    “聲明”為編譯服務,用于類型檢查 ;“定義”在運行時會分配空間,不能重復定義,同時具備聲明的功能
    2013-09-09
  • C++實現(xiàn)LeetCode(72.編輯距離)

    C++實現(xiàn)LeetCode(72.編輯距離)

    這篇文章主要介紹了C++實現(xiàn)LeetCode(72.編輯距離),本篇文章通過簡要的案例,講解了該項技術的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下
    2021-07-07
  • C++學習之指針的使用詳解

    C++學習之指針的使用詳解

    這篇文章主要為大家詳細介紹了C++中指針的相關知識,文中的示例代碼講解詳細,對我們的學習或工作有一定的價值,感興趣的小伙伴可以了解一下
    2023-03-03
  • C++日期類計算器的模擬實現(xiàn)舉例詳解

    C++日期類計算器的模擬實現(xiàn)舉例詳解

    兩個日期之間相隔天數(shù)的計算網(wǎng)上有許多的軟件,這里主要介紹如何使用C/C++語言來完成這樣的功能,下面這篇文章主要給大家介紹了關于C++日期類計算器的模擬實現(xiàn),需要的朋友可以參考下
    2023-04-04
  • C++的動態(tài)內(nèi)存管理你真的了解嗎

    C++的動態(tài)內(nèi)存管理你真的了解嗎

    這篇文章主要為大家詳細介紹了C++的動態(tài)內(nèi)存管理,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-02-02
  • C語言實現(xiàn)通訊錄系統(tǒng)

    C語言實現(xiàn)通訊錄系統(tǒng)

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)通訊錄系統(tǒng),文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-02-02
  • C語言實現(xiàn)簡易文本編譯器

    C語言實現(xiàn)簡易文本編譯器

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)簡易文本編譯器,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-05-05

最新評論