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;
}
运行结果如下:
相关推荐
java干货3 分钟前
为什么 “File 10“ 排在 “File 2“ 前面?解决文件名排序的终极算法:自然排序
开发语言·python·算法
_F_y3 分钟前
C语言重点知识总结(含KMP详细讲解)
c语言·开发语言
皮皮哎哟11 分钟前
数据结构:嵌入式常用排序与查找算法精讲
数据结构·算法·排序算法·二分查找·快速排序
程序员清洒20 分钟前
CANN模型剪枝:从敏感度感知到硬件稀疏加速的全链路压缩实战
算法·机器学习·剪枝
vortex534 分钟前
几种 dump hash 方式对比分析
算法·哈希算法
郝学胜-神的一滴1 小时前
深入解析C/S模型下的TCP通信流程:从握手到挥手的技术之旅
linux·服务器·c语言·网络·网络协议·tcp/ip
Wei&Yan2 小时前
数据结构——顺序表(静/动态代码实现)
数据结构·c++·算法·visual studio code
island13142 小时前
CANN GE(图引擎)深度解析:计算图优化管线、内存静态规划与异构 Stream 调度机制
c语言·开发语言·神经网络
团子的二进制世界2 小时前
G1垃圾收集器是如何工作的?
java·jvm·算法
吃杠碰小鸡2 小时前
高中数学-数列-导数证明
前端·数学·算法