C //习题10.4 有两个磁盘文件“A“和“B“,各存放一行字母,今要求把这两个文件中的信息合并(按字母顺序排列),输出到一个新文件“C“中去。

C程序设计 (第四版) 谭浩强 习题10.4

习题10.4 有两个磁盘文件"A"和"B",各存放一行字母,今要求把这两个文件中的信息合并(按字母顺序排列),输出到一个新文件"C"中去。

IDE工具:VS2010
Note: 使用不同的IDE工具可能有部分差异。
代码块
方法:使用指针,函数的模块化设计,动态分配内存
说明:文件A.txt,B.txt,C.txt已经存在于该项目目录下。
c 复制代码
#include <stdio.h>
#include <stdlib.h>

//初始化变量
void initialVar(char **name1, char **name2, char **name3){
	*name1 = (char*)malloc(80 * sizeof(char));
	*name2 = (char*)malloc(80 * sizeof(char));
	*name3 = (char*)malloc(80 * sizeof(char));
}

//输入文件名称
void inputFileName(FILE **file, char *name, int num){
	printf("Enter File%d Name: ", num);
	scanf("%s", name);

	char *sign = '\0';
	if(num == 1 || num == 2){
		sign = "r";
	}
	if(num == 3){
		sign = "w+";
	}

	*file = fopen(name, sign);
	if(*file == NULL){
		perror("Cannot open this file");
		system("pause");
		exit(0);
	}
	putchar(10);
}

//输出文件内容
void outputFile(FILE **file, int num){
	printf("File%d Content: ", num);
	while(!feof(*file)){
		putchar(fgetc(*file));
	}
	putchar(10);
}

//对文件内容进行排序
void sortFile(FILE **file, int count){
	char *arr = (char*)malloc(count * sizeof(char));
	for(int i = 0; i < count; i++){
		arr[i] = fgetc(*file);
	}
	rewind(*file);
	char temp;
	for(int i = 0; i < count; i++){
		for(int j = i + 1; j < count; j++){
			if(arr[i] > arr[j]){
				temp = arr[i];
				arr[i] = arr[j];
				arr[j] = temp;
			}
		}
	}
	for(int i = 0; i < count; i++){
		fputc(arr[i], *file);
	}
	rewind(*file);
}

//合并两个文件内容到第三个文件
void mergeFile(FILE **file1, FILE **file2, FILE **file3){
	rewind(*file1);
	rewind(*file2);

	int count = 0;
	while(!feof(*file1)){
		fputc(fgetc(*file1), *file3);
		count++;
	}
	fclose(*file1);

	while(!feof(*file2)){
		fputc(fgetc(*file2), *file3);
		count++;
	}
	rewind(*file3);
	sortFile(file3, count);
	outputFile(file3, 3);

	fclose(*file2);
	fclose(*file3);
}

//释放变量内存
void freeVar(char **name1, char **name2, char **name3){
	free(*name1);
	free(*name2);
	free(*name3);
}

int main(){
	FILE *file1 = NULL;
	FILE *file2 = NULL;
	FILE *file3 = NULL;
	char *name1 = NULL;
	char *name2 = NULL;
	char *name3 = NULL;

	initialVar(&name1, &name2, &name3);
	inputFileName(&file1, name1, 1);
	outputFile(&file1, 1);
	inputFileName(&file2, name2, 2);
	outputFile(&file2, 2);
	inputFileName(&file3, name3, 3);
	mergeFile(&file1, &file2, &file3);
	freeVar(&name1, &name2, &name3);

	system("pause");
	return 0;
}
运行结果如下:
相关推荐
luckys.one18 小时前
第9篇:Freqtrade量化交易之config.json 基础入门与初始化
javascript·数据库·python·mysql·算法·json·区块链
~|Bernard|19 小时前
在 PyCharm 里怎么“点鼠标”完成指令同样的运行操作
算法·conda
战术摸鱼大师19 小时前
电机控制(四)-级联PID控制器与参数整定(MATLAB&Simulink)
算法·matlab·运动控制·电机控制
Christo319 小时前
TFS-2018《On the convergence of the sparse possibilistic c-means algorithm》
人工智能·算法·机器学习·数据挖掘
鹿鹿学长20 小时前
2025年全国大学生数学建模竞赛(C题) 建模解析|婴儿染色体数学建模|小鹿学长带队指引全代码文章与思路
c语言·开发语言·数学建模
好家伙VCC20 小时前
数学建模模型 全网最全 数学建模常见算法汇总 含代码分析讲解
大数据·嵌入式硬件·算法·数学建模
伴杯猫20 小时前
【ESP32-IDF】基础外设开发2:系统中断矩阵
c语言·单片机·嵌入式硬件·mcu·物联网·github
liulilittle1 天前
IP校验和算法:从网络协议到SIMD深度优化
网络·c++·网络协议·tcp/ip·算法·ip·通信
Want5951 天前
C/C++圣诞树①
c语言·开发语言·c++
bkspiderx1 天前
C++经典的数据结构与算法之经典算法思想:贪心算法(Greedy)
数据结构·c++·算法·贪心算法