免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: cxytz01
打印 上一主题 下一主题

[算法] 求一取最大值得算法!!常见排序算法不要。 [复制链接]

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
51 [报告]
发表于 2013-01-10 19:47 |只看该作者
本帖最后由 yulihua49 于 2013-01-10 19:49 编辑
folklore 发表于 2013-01-10 18:09
@windoze用堆的话是log(n),
前提是本身有序。 此外,堆重整也要时间。
所以,堆适用于不关心数据的index, ...

完全不用任何的序。在accept后判定fd的最大值即可:


  1. int max_fd=-1,s;
  2. while(1) {
  3.       s=accept(...);
  4.      max_fd=MAX(max_fd,s);
  5.      ......
  6. }
复制代码

论坛徽章:
59
2015年亚洲杯之约旦
日期:2015-01-27 21:27:392015年亚洲杯之日本
日期:2015-02-06 22:09:41拜羊年徽章
日期:2015-03-03 16:15:432015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015元宵节徽章
日期:2015-03-06 15:50:392015年亚洲杯之阿联酋
日期:2015-03-19 17:39:302015年亚洲杯之中国
日期:2015-03-23 18:52:23巳蛇
日期:2014-12-14 22:44:03双子座
日期:2014-12-10 21:39:16处女座
日期:2014-12-02 08:03:17天蝎座
日期:2014-07-21 19:08:47
52 [报告]
发表于 2013-01-10 20:15 |只看该作者
@yulihua49人家还要删除

论坛徽章:
44
15-16赛季CBA联赛之浙江
日期:2021-10-11 02:03:59程序设计版块每日发帖之星
日期:2016-07-02 06:20:0015-16赛季CBA联赛之新疆
日期:2016-04-25 10:55:452016科比退役纪念章
日期:2016-04-23 00:51:2315-16赛季CBA联赛之山东
日期:2016-04-17 12:00:2815-16赛季CBA联赛之福建
日期:2016-04-12 15:21:2915-16赛季CBA联赛之辽宁
日期:2016-03-24 21:38:2715-16赛季CBA联赛之福建
日期:2016-03-18 12:13:4015-16赛季CBA联赛之佛山
日期:2016-02-05 00:55:2015-16赛季CBA联赛之佛山
日期:2016-02-04 21:11:3615-16赛季CBA联赛之天津
日期:2016-11-02 00:33:1215-16赛季CBA联赛之浙江
日期:2017-01-13 01:31:49
53 [报告]
发表于 2013-01-10 20:45 |只看该作者
yulihua49 发表于 2013-01-10 19:47
完全不用任何的序。在accept后判定fd的最大值即可:


对于总共n个连接,难道那个循环不用执行n次?

论坛徽章:
2
程序设计版块每日发帖之星
日期:2015-06-17 22:20:00每日论坛发贴之星
日期:2015-06-17 22:20:00
54 [报告]
发表于 2013-01-10 20:49 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
55 [报告]
发表于 2013-01-10 21:22 |只看该作者
本帖最后由 yulihua49 于 2013-01-10 21:30 编辑
windoze 发表于 2013-01-10 20:45
对于总共n个连接,难道那个循环不用执行n次?

当然是n次,但是分散了,而且只对少数有效连接操作,不用对数组的大部分-1操作。
此n非彼n。
此n是每次连接一次,可能比彼n少,也可能多。但是相对于耗时冗长的连接活动,它的开销忽略不计。虽然是O(n),但其前边的系数是0!!!

0O(n), 明白吗?
这种问题,理论上吃干轧净了,不会有新发明,在前边的系数上下下工夫吧。

论坛徽章:
1
技术图书徽章
日期:2014-03-06 15:32:30
56 [报告]
发表于 2013-01-10 21:35 |只看该作者
你要解决的问题,是这个系统的瓶颈吗?
回答这个问题之前,别拍脑袋,拿测试代码和测试结果说话。

论坛徽章:
0
57 [报告]
发表于 2013-01-10 21:41 |只看该作者
回复 42# cxytz01


    别说一万,两三千就不行了。参考一下这个http://lse.sourceforge.net/epoll/index.html
    select和poll的性能几乎是一样的,检测到事件之后,就必须要扫一遍fd_set,每次读数据之前都循环一万次,性能能好吗?

论坛徽章:
1
双子座
日期:2013-11-14 17:43:24
58 [报告]
发表于 2013-01-10 21:59 |只看该作者
回复 49# folklore


    建堆的复杂度是O(n)。删除堆顶元素,然后调整堆的复杂度是O(logN),向堆中插入元素复杂度是O(logN)

论坛徽章:
59
2015年亚洲杯之约旦
日期:2015-01-27 21:27:392015年亚洲杯之日本
日期:2015-02-06 22:09:41拜羊年徽章
日期:2015-03-03 16:15:432015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:50:282015元宵节徽章
日期:2015-03-06 15:50:392015年亚洲杯之阿联酋
日期:2015-03-19 17:39:302015年亚洲杯之中国
日期:2015-03-23 18:52:23巳蛇
日期:2014-12-14 22:44:03双子座
日期:2014-12-10 21:39:16处女座
日期:2014-12-02 08:03:17天蝎座
日期:2014-07-21 19:08:47
59 [报告]
发表于 2013-01-10 22:02 |只看该作者
@star_in_sky
这个。。。。


































































































不可能有小于nlog(n)的排序算法。。。

论坛徽章:
44
15-16赛季CBA联赛之浙江
日期:2021-10-11 02:03:59程序设计版块每日发帖之星
日期:2016-07-02 06:20:0015-16赛季CBA联赛之新疆
日期:2016-04-25 10:55:452016科比退役纪念章
日期:2016-04-23 00:51:2315-16赛季CBA联赛之山东
日期:2016-04-17 12:00:2815-16赛季CBA联赛之福建
日期:2016-04-12 15:21:2915-16赛季CBA联赛之辽宁
日期:2016-03-24 21:38:2715-16赛季CBA联赛之福建
日期:2016-03-18 12:13:4015-16赛季CBA联赛之佛山
日期:2016-02-05 00:55:2015-16赛季CBA联赛之佛山
日期:2016-02-04 21:11:3615-16赛季CBA联赛之天津
日期:2016-11-02 00:33:1215-16赛季CBA联赛之浙江
日期:2017-01-13 01:31:49
60 [报告]
发表于 2013-01-10 22:20 |只看该作者
回复 55# yulihua49

原来只要“忽略不计”,复杂度就可以变成O(0)的,楼上的高度果然有好几十层楼那么高……
干脆以后就表优化神马程序了,反正对于宇宙几十亿年漫长的寿命而言,程序执行的那点时间都可以忽略不计的
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP