搜索
编程论坛
→
开发语言
→
『 数据结构与算法 』
→ 请问两两配对的算法,求想法!不求code!
标题:
请问两两配对的算法,求想法!不求code!
只看楼主
zeuso0
等 级:
新手上路
帖 子:3
专家分:0
注 册:2010-11-5
结帖率:
0
楼主
已结贴
√
问题点数:20 回复次数:1
请问两两配对的算法,求想法!不求code!
小明有n个螺丝和n个螺帽,每个螺丝对应一个特定螺帽。 所有螺丝长一样,所有螺帽张一样肉眼无法区别。只能通过拿螺丝去试螺帽,看螺纹是大了,小了,是正好才能配对好。你会想到什么样有效的算法帮小明一一配对成功??
这样两两配对的算法是什么算法??怎样的实现的??
搜索更多相关主题的帖子:
code
算法
配对
2010-11-05 13:05
Tveiker
来 自:湖南省张家界桑植
等 级:
论坛游民
帖 子:17
专家分:41
注 册:2010-9-28
第
2
楼
得分:20
最基本算法:
先定义两个类。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)
如果是链表实现,思想差不多
2010-11-05 13:35
2
1/1页
1
参与讨论请移步原网站贴子:
https://bbs.bccn.net/thread-325059-1-1.html
关于我们
|
广告合作
|
编程中国
|
清除Cookies
|
TOP
|
手机版
编程中国
版权所有,并保留所有权利。
Powered by
Discuz
, Processed in 0.012669 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved