免费注册 查看新帖 |

Chinaunix

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

一道算法题 [复制链接]

论坛徽章:
0
51 [报告]
发表于 2008-09-26 17:47 |只看该作者

回复 #1 anselcat 的帖子

you yisi

论坛徽章:
0
52 [报告]
发表于 2008-09-26 18:23 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
53 [报告]
发表于 2008-09-26 22:35 |只看该作者
提示: 作者被禁止或删除 内容自动屏蔽

论坛徽章:
0
54 [报告]
发表于 2008-11-01 18:05 |只看该作者
如果不考虑最大容量的话,可以这样设计:
1.计算整个数组的平均值;
2.从A[0]开始遍历数组,每找到一个大于平均值的数,记录该下标值,转到下步3;若无大于平均值的则完成开闸平衡;
3.从2步的下标开始,向两边找小于平均值的;正向(即数组下标为i+1)找到则方向控制为1,反向(即数组下标为n-i-1)为-1,退出按方向控制开始开闸,即最短的路径;回2,从2步记录的下标值开始继续遍历;

时间复杂度<O(n^2/4),最佳是o(N/2).
说明:N为偶时为N,N为奇时N+1;

[ 本帖最后由 nikia 于 2008-11-2 19:02 编辑 ]
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP