将数据从文件中读出并排序

72 阅读1分钟
#include <stdio.h>
#include <stdlib.h>
void read();//显示排序之前的文件
void outfile();//输入到数组中
void sort(int a[], int n);//此处为冒泡排序
int main()
{
    read();
    outfile();
    return 0;
}
void read()
{
    printf("after of sort:\n");
    FILE *fp;//文件指针
    char ch;
    if((fp = fopen("F:\\Codes\\Codeblocks\\C\\FileSort\\sort.txt","r"))==NULL)//文件的路径
    {
        printf("Can not open this file!\n");//找不到文件时结束
        exit(0);
    }
    ch = fgetc(fp);//获取文件中的字符
    while(!feof(fp))//判断是否到文件末尾
    {
        putchar(ch);//输出字符
        ch = fgetc(fp);
    }
    printf("\n");
    fclose(fp);//关闭文件
}
void outfile()
{
    int k = 1;//行数,最后一行结束时不进入循环,所以初值为1
    FILE *fp;//文件指针
    if((fp = fopen("F:\\Codes\\Codeblocks\\C\\FileSort\\sort.txt","r"))==NULL)//文件的路径
    {
        printf("Can not open this file!\n");//找不到文件时结束
        exit(0);
    }
    int c;
    while((c = fgetc(fp)) != EOF)//获取文件总行数
    {
        if(c == '\n')//文件到达换行符时行数加1
        {
            k++;
        }
    }
    fclose(fp);
    FILE *fp1;//文件指针
    if((fp1 = fopen("F:\\Codes\\Codeblocks\\C\\FileSort\\sort.txt","r"))==NULL)//文件的路径
    {
        printf("Can not open this file!\n");//找不到文件时结束
        exit(0);
    }
    int i,a[k];
    for(i = 0; !feof(fp); i++)//判断是否到达文件末尾
    {
        fscanf(fp,"%d",&a[i]);
    }
    fclose(fp1);
    sort(a, k);
}
void sort(int a[], int n)
{
    int i,j,temp;
    for(i = 0; i < n; i++)
    {
        for(j = 0; j < n - 1 - i; j++)
        {
            if(a[j] < a[j + 1])//交换数据
            {
                temp = a[j];
                a[j] = a[j + 1];
                a[j + 1] = temp;
            }
        }
    }
    printf("later of sort:\n");//输出数组
    for(i = 0; i < n; i++)
    {
        printf("%d\n",a[i]);
    }
}

       注意当求文件总行数时,要先求出来,然后把文件关闭,最后再对文件进行输出。否则,当文件没有关闭,求总行数已经读到文件最后,求出的数组全为0。
\