设为首页
收藏本站
用户名
Email
自动登录
找回密码
密码
登录
注册
快捷导航
平台
Portal
论坛
BBS
文库
项目
群组
Group
我的博客
Space
搜索
搜索
热搜:
shell
linux
mysql
本版
用户
LinuxSir.cn,穿越时空的Linuxsir!
»
论坛
›
编程开发讨论区 —— LinuxSir.cn
›
Linux 程序设计专题讨论
›
问:从顺序表中删除值相同的节点的算法 ...
返回列表
查看:
1093
|
回复:
6
问:从顺序表中删除值相同的节点的算法
[复制链接]
Xiangbuilder
Xiangbuilder
当前离线
积分
259
IP卡
狗仔卡
发表于 2006-3-6 18:42:45
|
显示全部楼层
|
阅读模式
这个程序的时间复杂度是不是n^3?
有没有可能更小?
回复
使用道具
举报
提升卡
置顶卡
沉默卡
喧嚣卡
变色卡
显身卡
rickxbx
rickxbx
当前离线
积分
1256
IP卡
狗仔卡
发表于 2006-3-7 17:44:26
|
显示全部楼层
n+(n-1)+(n-2)+...+1 是 n^2,有没有好的算法不清楚
回复
支持
反对
使用道具
举报
显身卡
Xiangbuilder
Xiangbuilder
当前离线
积分
259
IP卡
狗仔卡
楼主
|
发表于 2006-3-7 18:41:18
|
显示全部楼层
从第一个结点开始进行搜索,查找值相同的结点,完了之后,
再从下一个结点开始搜索整个表,查找值相同的结点,
直至最后一个结点,
这样时间复杂度是n^2,
但如果再加上删除的操作,就不止n^2,
顺序表中删除某一个特定结点的时间复杂度是n
所以我觉得时间复杂度最小为n^3,
不知道这个想是不是正确?
回复
支持
反对
使用道具
举报
显身卡
rickxbx
rickxbx
当前离线
积分
1256
IP卡
狗仔卡
发表于 2006-3-7 19:47:20
|
显示全部楼层
不是链表吗?
回复
支持
反对
使用道具
举报
显身卡
Xiangbuilder
Xiangbuilder
当前离线
积分
259
IP卡
狗仔卡
楼主
|
发表于 2006-3-7 19:49:28
|
显示全部楼层
是顺序表啊。
回复
支持
反对
使用道具
举报
显身卡
rickxbx
rickxbx
当前离线
积分
1256
IP卡
狗仔卡
发表于 2006-3-7 22:07:06
|
显示全部楼层
不好意思,没理解顺序表的意思。一开始只认为了线性表了
回复
支持
反对
使用道具
举报
显身卡
kakuyou
kakuyou
当前离线
积分
52
IP卡
狗仔卡
发表于 2006-3-9 10:53:39
|
显示全部楼层
如果是大表可能才需要吧。
说个耗内存的方法。
建立原表的index表,进行index快速排序,因为快速排序在最糟的情况下是n的2次方。
然后进行末尾交换,不断的交换最末尾的元素和重合的元素,最后所有值相同的元素就
被放在最后了。
回复
支持
反对
使用道具
举报
显身卡
返回列表
高级模式
B
Color
Image
Link
Quote
Code
Smilies
您需要登录后才可以回帖
登录
|
注册
本版积分规则
发表回复
回帖后跳转到最后一页
Copyright © 2002-2023
LinuxSir.cn
(http://www.linuxsir.cn/) 版权所有 All Rights Reserved.
Powered by
RedflagLinux!
技术支持:
中科红旗
|
京ICP备19024520号
快速回复
返回顶部
返回列表