用记事本创建org.txt文件,往其中写入一组已排好序的整数数列,再由键盘输入一个整数,按排序的规律插入数列中,最后将数列仍写入文件org.txt中。例如:原整数数列为:3 6 9 11 55。将35插入后,输出数列为3 6 9 11 35 55。
#include <stdio.h>
#define N 100
int main()
{
int a[N]={0},i = 0,n,k = 0;
FILE *fp;
fp = fopen("org.txt","r");
if(fp == NULL) return -1;
while(1){ //从文件读取数据
if(fscanf(fp,"%d",&a[k]) != 1) break;
k++;
}
fclose(fp);
printf("数据读入成功,请输入待插入数:");
scanf("%d", &n); //输入待插入的数
if (n > a[k- 1]) {//插入操作
a[k] = n;
}
else {
for (i = k; n < a[i - 1] && i > 0; i--) {
a[i] = a[i - 1];
}
a[i] = n;
}
fp = fopen("org.txt","w"); //输出及写回文件
if(fp == NULL) return -1;
for (i = 0; i < k + 1; i++){//输出 插入数后的有序数列
printf("%4d", a[i]);
fprintf(fp,"%d ",a[i]); //写数据到文件
}
fclose(fp);
printf("\n");
return 0;
}
逻辑上和楼上的差不多,主要在于省略一次 for 循环操作,写文件的时候,直接判断写入的顺序
#include <stdio.h>
/*
用记事本创建org.txt文件,往其中写入一组已排好序的整数数列,再由键盘输入一个整数,
按排序的规律插入数列中,最后将数列仍写入文件org.txt中。
例如:原整数数列为:3 6 9 11 55。将35插入后,输出数列为3 6 9 11 35 55
*/
int main()
{
// 创建文件
FILE *file = fopen("org.txt", "w+");
// 初始化数据
int arr[] = { 3, 6, 9, 11, 55 };
// 循环将数据写到文件
int i = 0;
for (i = 0; i < sizeof(arr)/sizeof(int); i++)
{
fprintf(file, "%d ", arr[i]);
}
// 文件中写入换行
fprintf(file, "\n");
fflush(file);
// 键盘获取新的数据
int input = -1;
scanf("%d", &input);
// 排序更新文件内容,简化逻辑,原来的数据已经排序了,写到文件的时候判断就好了,无需单独的排序操作
for (i = 0; i < sizeof(arr) / sizeof(int); i++)
{
if (input < arr[i] && input != -1)
{
fprintf(file, "%d ", input);
}
fprintf(file, "%d ", arr[i]);
}
fflush(file);
fclose(file);
}