LinuxSir.cn,穿越时空的Linuxsir!

 找回密码
 注册
搜索
热搜: shell linux mysql
查看: 1094|回复: 6

问:从顺序表中删除值相同的节点的算法

[复制链接]
发表于 2006-3-6 18:42:45 | 显示全部楼层 |阅读模式
这个程序的时间复杂度是不是n^3?
有没有可能更小?
发表于 2006-3-7 17:44:26 | 显示全部楼层
n+(n-1)+(n-2)+...+1 是 n^2,有没有好的算法不清楚
回复 支持 反对

使用道具 举报

 楼主| 发表于 2006-3-7 18:41:18 | 显示全部楼层
从第一个结点开始进行搜索,查找值相同的结点,完了之后,
再从下一个结点开始搜索整个表,查找值相同的结点,
直至最后一个结点,
这样时间复杂度是n^2,

但如果再加上删除的操作,就不止n^2,
顺序表中删除某一个特定结点的时间复杂度是n
所以我觉得时间复杂度最小为n^3,

不知道这个想是不是正确?
回复 支持 反对

使用道具 举报

发表于 2006-3-7 19:47:20 | 显示全部楼层
不是链表吗?
回复 支持 反对

使用道具 举报

 楼主| 发表于 2006-3-7 19:49:28 | 显示全部楼层
是顺序表啊。
回复 支持 反对

使用道具 举报

发表于 2006-3-7 22:07:06 | 显示全部楼层
不好意思,没理解顺序表的意思。一开始只认为了线性表了
回复 支持 反对

使用道具 举报

发表于 2006-3-9 10:53:39 | 显示全部楼层
如果是大表可能才需要吧。

说个耗内存的方法。

建立原表的index表,进行index快速排序,因为快速排序在最糟的情况下是n的2次方。

然后进行末尾交换,不断的交换最末尾的元素和重合的元素,最后所有值相同的元素就
被放在最后了。
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

快速回复 返回顶部 返回列表