100分 c语言对比两个文件

要求用C语言读取两个文件(文件格式不限例如.txt,.c等),然后对比两个文件的不同(忽略字母大小写、空格、换行的处理),最后输出比较结果(完全相同语句提示或不同文件名及其内容所在的行号)。谢谢了,希望给出注释,答好可追加分数。
十分感谢两位的回答,问题已解决

最长公共子序列方法比较两个文件的相似性。输入两个文件的名字,输出一个文件,不同的地方用红色标出。

#include <stdio.h>
#include <string.h>
#include <stdlib.h>

#define max(x,y) (((x)>(y))?(x):(y))

int LCS(char *str1, char *same1, int len1, char *str2, char *same2, int len2)
{
int same, i, j;
int **midLCS;

midLCS = (int **)malloc(sizeof(int *) * (len1 + 1));
for (i = 0; i <= len1; i++) {
midLCS[i] = (int *)malloc(sizeof(int) * (len2 + 1));
}
for (i = 0; i <= len1; i++) {
midLCS[i][0] = 0;
}
for (i = 0; i <= len2; i++) {
midLCS[0][i] = 0;
}

for (i = 1; i <= len1; i++)
{
for (j = 1; j <= len2; j++)
{
if (str1[i - 1] == str2[j - 1]) {
midLCS[i][j] = midLCS[i - 1][j - 1] + 1;
}
else {
midLCS[i][j] = max(midLCS[i - 1][j], midLCS[i][j - 1]);
}
}
}

for (i = len1, j = len2; i > 0 && j > 0; )
{
if (str1[i - 1] == str2[j - 1]) {
same1[i - 1] = 1;
same2[j - 1] = 1;
--i;
--j;
}
else if (midLCS[i - 1][j] > midLCS[i][j - 1]) {
--i;
}
else {
--j;
}
}

same = midLCS[len1][len2];
for (i = 0; i <= len1; i++) {
free(midLCS[i]);
}
free(midLCS);

return same;
}

void show_compare(char *str, char *same, int len, FILE *fout)
{
int i, flag = 0;

for (i = 0; i < len; i++)
{
if (str[i] == '\n') {
fprintf(fout, " <br> ");
}
else if (str[i] == '\t') {
fprintf(fout, " ");
}
else {
if (same[i] == 1) {
if (flag == 1) {
fprintf(fout, " </font> ");
flag = 0;
}
fputc(str[i], fout);
}
else {
if (flag == 0) {
fprintf(fout, " <font color=red> ");
flag = 1;
}
fputc(str[i], fout);
}
}
}
if (flag == 1)
fprintf(fout, " </font> ");
}

int main()
{
int i, len1, len2;
FILE *fin1, *fin2, *fout;
char buf[1024];
char *str1, *str2, *same1, *same2;

printf("file1: ");
scanf("%s", buf);
fin1 = fopen(buf, "rb");
if (fin1 == NULL) {
printf("%s not exist!\n", buf);
return 0;
}
printf("file2: ");
scanf("%s", buf);
fin2 = fopen(buf, "rb");
if (fin2 == NULL) {
printf("%s not exist!\n", buf);
return 0;
}
fout = fopen("compare.html", "w+");

fseek(fin1, 0, SEEK_END);
len1 = (int)ftell(fin1);
fseek(fin1, 0, SEEK_SET);
fseek(fin2, 0, SEEK_END);
len2 = (int)ftell(fin2);
fseek(fin2, 0, SEEK_SET);

str1 = (char *)malloc(sizeof(char) * len1);
str2 = (char *)malloc(sizeof(char) * len2);
same1 = (char *)malloc(sizeof(char) * len1);
same2 = (char *)malloc(sizeof(char) * len2);
fread(str1, 1, len1, fin1);
fread(str2, 1, len2, fin2);

LCS(str1, same1, len1, str2, same2, len2);

show_compare(str1, same1, len1, fout);
fprintf(fout, " ----------------------------------------------------------------<br> ");
show_compare(str2, same2, len2, fout);

free(str1);
free(str2);
free(same1);
free(same2);
fclose(fin1);
fclose(fin2);
fclose(fout);

}
温馨提示:内容为网友见解,仅供参考
第1个回答  2009-07-06
//奇怪啊,我试了是可以的啊~
//非常简单的程序,对比a.dat和b.dat是否相同
#include<stdio.h>

void main()
{
FILE *fp1,*fp2;
fp1 = fopen("a.dat","rb");
fp2 = fopen("b.dat","rb");
int n=0;
unsigned a,b;
while( (!feof(fp1)) && (!feof(fp2)) )
{
fread(&a,1,1,fp1);
fread(&b,1,1,fp2);
if(a != b)
{
n=1;
break;
}
}
if(n==1)
printf("no same!\n");
else
printf("same!\n");
fclose(fp1);
fclose(fp2);
}

100分 c语言对比两个文件
int LCS(char *str1, char *same1, int len1, char *str2, char *same2, int len2){ int same, i, j;int **midLCS;midLCS = (int **)malloc(sizeof(int *) * (len1 + 1));for (i = 0; i <= len1; i++) { midLCS[i] = (int *)malloc(sizeof(int) * (len2...

C语言机考是怎么给分的
在C语言机考中,评分过程大致如下:如果有out.dat文件,那么评分系统会将该文件与标准答案中的out.dat文件进行对比,根据两文件内容相符的比例来给分。若完全相同,则可以获得满分100分。如果没有out.dat文件,评分系统则会比较考生编写的代码与标准答案代码的相符程度,根据相符度来给分。例如,在一个真...

C语言 对比2文本,取出不重复值。
把B的内容fopen打开,然后fgets获取每一行到链表,二叉树算法查询快点.比较用strcmp.A也可以这么处理.最后再B和A比较就可以了

怎么对比两个文件夹中的文件内容,把不同的内容输出到一个新的文件夹?C...
for(int i=0;i<test.length;i++){ file=new File(filePath+File.separator+test[i]); 判断你的另外一个文件夹里是否有这个文件 你在这里判断这个file是否为空就知道有没有这个文件了 file.delete(); 我这里是如果有就删除 当然你想怎么处理这里看你自己。不要想着别人把代码完完全全写出...

如何实现在C语言中对两个字符串里面的内容进行对比
其实只要遇到空格跳过就好了。这里我们假设空格(' '),制表符('\\t')和回车符('\\n')是要忽略的字符。假设两个字符串已经在str1 和 str2里面存好了。int len1 = strlen(str1), len2 = strlen(str2);int i = 0, j = 0; \/* i: Pointer of str1, j: Pointer of str2 *\/int ...

请教C语言,对比如下两个函数的差异
第一个函数是交换了两个指针量所指向的值。第二个函数是直接交换了两个指针变量。

如何比较两个文件夹中文件名相同的文件,并将其输出来。最好输出到文档...
in_file) return 0; string file_name; while (getline(in_file, file_name)) { string file_path = ".\/B\/" + file_name; ifstream out_file(file_path.c_str()); if (out_file) { cout << file_name << " : " << endl; string file_line; ...

C语言怎么比较两张图片是否是同一张图片
遍历像素,对比RGB的颜色差。C语言的话用GTK库,EGE。EasyX貌似要把文件名变成.cpp的。不是纯C语言。你用了easyX.h就知道了。include "graphics.h"float IsMatch(Iamge *a,Image *b )\/\/传两个Image结构体指针进去{int same=0,sum;\/\/相同像素,总像素int x,y,W=a->getwidth(),H=a->get...

求解几道C语言试题,急!!!
1 主函数,输入学生个数n,开辟内存空间,组织调用其他函数,输入统计结果 2 输入函数,输入n个学生的数据 3 统计函数,统计男女前三名 (4) 我们需要同时处理三个文件。文件addr.txt记录了某些人的姓名和地址;文件tel.txt记录了顺序不同的上述人的姓名和电话号码。希望通过对比两个文件,将同一人的...

C语言比较两个字符串相等的问题,请人详细讲解
'c''d''e''\\0'strcmp的参数都是char*,也就是指向字符的指针,原理是从两个指针指向的地址开始对比,直到其中一个\\0为止。判断相等与否。实现上是每个字符相减。单纯的==,比较的是字符串手地址是否相等,这样比较,不但比较不了两个字符串相等与否,而且要想相等,还必须两个字符串指向同一个地址...

相似回答