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;
}
运行结果如下:
相关推荐
passer__jw76719 分钟前
【LeetCode】【算法】283. 移动零
数据结构·算法·leetcode
Ocean☾26 分钟前
前端基础-html-注册界面
前端·算法·html
顶呱呱程序34 分钟前
2-143 基于matlab-GUI的脉冲响应不变法实现音频滤波功能
算法·matlab·音视频·matlab-gui·音频滤波·脉冲响应不变法
TeYiToKu1 小时前
笔记整理—linux驱动开发部分(9)framebuffer驱动框架
linux·c语言·arm开发·驱动开发·笔记·嵌入式硬件·arm
互联网打工人no11 小时前
每日一题——第一百二十四题
c语言
爱吃生蚝的于勒1 小时前
深入学习指针(5)!!!!!!!!!!!!!!!
c语言·开发语言·数据结构·学习·计算机网络·算法
羊小猪~~1 小时前
数据结构C语言描述2(图文结合)--有头单链表,无头单链表(两种方法),链表反转、有序链表构建、排序等操作,考研可看
c语言·数据结构·c++·考研·算法·链表·visual studio
洋2401 小时前
C语言常用标准库函数
c语言·开发语言
王哈哈^_^1 小时前
【数据集】【YOLO】【VOC】目标检测数据集,查找数据集,yolo目标检测算法详细实战训练步骤!
人工智能·深度学习·算法·yolo·目标检测·计算机视觉·pyqt
星沁城1 小时前
240. 搜索二维矩阵 II
java·线性代数·算法·leetcode·矩阵