题目
解决代码及点评
/*
有两个磁盘文件,各自存放已排好序的若干个字符(如a1. dat 中放"abort", a2.dat中放 "boy")
要求将两个文件合并,合并后仍保持有序,存放在a3.dat文件中。
提示:可先将两个文件中的字符存入一个字符型数组中,而后对数组重新排序,再将该数组写入a3.dat文件中。
如果不引入一个中间数组进行重新排序,该如何编程?
*/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <ctype.h>
#define SWAP(x,y) {char tmp; tmp = (x); (x)=(y); (y)=tmp;}
static void str_sort(char *str, int str_size)
{
int i,j;
for (i = 0; i < str_size; i++)
{
for (j = str_size - 2; j >= i; j--)
{
if (str[j] > str[j+1])
{
SWAP(str[j],str[j+1]);
}
}
}
}
int main()
{
FILE *fp = NULL;
char str[128] = "";
char *p = str;
fopen_s(&fp, "a1.dat", "r");//打开a1.dat
if (fp == NULL)
{
fopen_s(&fp, "a1.dat", "w+");//读写
fprintf(fp, "%s", "abort");
rewind(fp);
}
fscanf_s(fp, "%s", str);
fclose(fp);
p = str+strlen(str);//p移动到末尾
fopen_s(&fp, "a2.dat", "r");//打开a2.dat
if (fp == NULL)
{
fopen_s(&fp, "a2.dat", "w+");//读写
fprintf(fp, "%s", "boy");
rewind(fp);
}
fscanf_s(fp, "%s", p);
fclose(fp);
str_sort(str, strlen(str));//对str[]进行排序
printf("%s\n", str);
fopen_s(&fp, "a3.dat", "w");//将str写入a3.dat
fprintf(fp, "%s", str);
fclose(fp);
return 0;
}
代码编译以及运行
由于资源上传太多,资源频道经常被锁定无法上传资源,同学们可以打开VS2013自己创建工程,步骤如下:
1)新建工程
2)选择工程
3)创建完工程如下图:
4)增加文件,右键点击项目
5)在弹出菜单里做以下选择
6)添加文件
7)拷贝代码与运行
程序运行结果