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;
}
运行结果如下:
相关推荐
VALENIAN瓦伦尼安教学设备几秒前
便携式蒸汽阀门漏气检测仪作用
人工智能·嵌入式硬件·算法
plus4s2 分钟前
3月11日(进阶3)
算法
We་ct6 分钟前
LeetCode 39. 组合总和:DFS回溯解法详解
前端·算法·leetcode·typescript·深度优先·个人开发·回溯
小杍随笔7 分钟前
【Rust中所有符号的作用及使用场景详解】
java·算法·rust
MicroTech202511 分钟前
微算法科技(NASDAQ: MLGO)探索量子机器学习算法在预测模型中的应用,利用量子核方法提升复杂模式识别能力
科技·算法·机器学习
absunique1 小时前
算法设计模式看编程思维的抽象能力的技术6
算法·设计模式
DeepModel2 小时前
【概率分布】Beta分布详解
算法·概率论
我命由我123452 小时前
React - 验证 Diffing 算法、key 的作用
javascript·算法·react.js·前端框架·html·html5·js
Eward-an6 小时前
LeetCode 1980 题通关指南|3种解法拆解“找唯一未出现二进制串”问题,附Python最优解实现
python·算法·leetcode
程序员酥皮蛋6 小时前
hot 100 第四十题 40.二叉树的层序遍历
数据结构·算法·leetcode