比较两个数组元素的变化 有没有更好的算法

xueshi 2005-12-08 12:29:30
char M1[m] = {'A','C','D','F','G'}
char M2[n] = {'A','B','C','G','H'}

说白了 就是先前记录一个数组的信息 过一段时间看看 数组的个数,元素是否发生变化

我想了一个笨方法 ,还没有实现

for(int i=0;i<m;i++)
{
for(int j=0;j<n;j++)
{
if(!strcmp(M1[i],M2[j]))
{
//如果相同,则跳到最外层循环,对M1[i+1]进行比较
//请问怎么从双层循环跳到最外层循环啊?? goto?
}
else
{
//生成报警内容
}

}
}

其他朋友还有好的方法吗?
真心请教
...全文
302 10 打赏 收藏 转发到动态 举报
写回复
用AI写文章
10 条回复
切换为时间正序
请发表友善的回复…
发表回复
thisisll 2005-12-08
  • 打赏
  • 举报
回复
happyparrot(快乐鹦鹉) ( 三星(高级)) 信誉:166 2005-12-08 12:45:00 得分:0
?
要看是否发生变化,不如将两个char数组转成CString类型,然后利用该类很容易判断内容和个数是否相同

这个方法比较好
goodboyws 2005-12-08
  • 打赏
  • 举报
回复
全面比较可以这样
首先保证你的数组是有序的
int i=0; j=0;
while (i<m && j<n)
{
if (M1[i] < M2[j])
{
//生成报警内容
i++;
}
else if (M1[i] > M2[j])
{
//生成报警内容
j++;
}
else
{
i++;
j++;
}
}
快乐鹦鹉 2005-12-08
  • 打赏
  • 举报
回复
要看是否发生变化,不如将两个char数组转成CString类型,然后利用该类很容易判断内容和个数是否相同
goodboyws 2005-12-08
  • 打赏
  • 举报
回复
简单的可以这样
for (int i=0, j=0; i< 3 && j<3; i++, j++)
{
if (strcmp(M1[i],M2[j]))
{ //生成报警内容
break;
}
}
rageliu 2005-12-08
  • 打赏
  • 举报
回复
break就出2层循环了
ming6424 2005-12-08
  • 打赏
  • 举报
回复
数组的地址应该是连续的吧
memcmp行不行???
kingcalf 2005-12-08
  • 打赏
  • 举报
回复
不太明白你的意思,strcmp函数的原型是:
int strcmp ( const char * string1, const char * string2 );
它的两个参数应该是:const char* 才对
如果只要数组不相等就发出警报,这样就可以:
int min = m<n : m ? n;
if(strncmp(M1,M2,min))
{
//生成警报内容
}
Featured 2005-12-08
  • 打赏
  • 举报
回复
不如将两个char数组转成CString类型,然后利用该类很容易判断内容和个数是否相同
===
CString内部判别是否相同还是要一番!@#@!$@的吧
goodboyws 2005-12-08
  • 打赏
  • 举报
回复
第二种算法能够满足你的要求,不过前提是必须是有序数组
xueshi 2005-12-08
  • 打赏
  • 举报
回复
不知 是不是我理解的有问题

To goodboyws(深夜不眠者)

你的算法 i和j是相同变化啊

我的意思 如果M1[1]和M2[2]相同 也是允许的




break 我理解了 谢谢

可是 我的功能还是没有实现 我现在是只要发现不同就报警

有没有都比较晚了之后再报警啊

16,551

社区成员

发帖
与我相关
我的任务
社区描述
VC/MFC相关问题讨论
社区管理员
  • 基础类社区
  • Creator Browser
  • encoderlee
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

        VC/MFC社区版块或许是CSDN最“古老”的版块了,记忆之中,与CSDN的年龄几乎差不多。随着时间的推移,MFC技术渐渐的偏离了开发主流,若干年之后的今天,当我们面对着微软的这个经典之笔,内心充满着敬意,那些曾经的记忆,可以说代表着二十年前曾经的辉煌……
        向经典致敬,或许是老一代程序员内心里面难以释怀的感受。互联网大行其道的今天,我们期待着MFC技术能够恢复其曾经的辉煌,或许这个期待会永远成为一种“梦想”,或许一切皆有可能……
        我们希望这个版块可以很好的适配Web时代,期待更好的互联网技术能够使得MFC技术框架得以重现活力,……

试试用AI创作助手写篇文章吧