最基本算法:
先定义两个类。1、LuoSi
2、LuoMao;
为了判别他们是否搭配,肯定得为他们各自写一个特征量。最简单就是编号ID。如LuoSi 的ID为1的和LuoMao的ID为1的能进行搭配,故而这两个类各自至少有个私有变量ID。
至于实现要需的函数因人而异。
实现思想基本如下
由于有n个螺丝和螺帽,故而考虑使用线性表。数组以及链表实现。
当LuoSi不为空{
再将LuoMao从下标0到最后一个循环寻找LuoSi[0]配对项,
当两者配对成功,则将这两者输出相应信息,并从各自线性表中删除,并移动需要移动的项(例如LuoSi[0]与LuoMao[0]配对成功,将其删除,并将后面个项依次前移)
}
直到全部配对完成为止
该算法时间复杂度O(n*n)
如果是链表实现,思想差不多