| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 949 人关注过本帖
标题:今天参加笔试,遇到一题!求讲解!
只看楼主 加入收藏
船长狙击手
Rank: 1
来 自:湖北
等 级:新手上路
帖 子:6
专家分:2
注 册:2011-11-27
结帖率:0
收藏
已结贴  问题点数:20 回复次数:4 
今天参加笔试,遇到一题!求讲解!
已知两个升序数组均为K个元素 A[K],B[K];已知1《=i,j《=k;求(ai +bj)中最小的K个!要求效率最高!本人思考半天,只能用最笨的方法解出!你们能用什么效率搞得算法解决这道题吗?
搜索更多相关主题的帖子: 元素 
2013-05-20 12:15
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:20 
int s1[K-1] = {a[1]- a[0], a[2] - a[1]...};
int s2[K-1] = {b[1]- a[0], b[2] - b[1]...};
int ans[K] = {a[0] + b[0]};

for (i = j = 0;i + j < k-1;)
{
    if      (s1[i] > s2[j])  ans[i+j+1] = ans[i+j] + s2[j++];
    else if (s1[i] < s2[j])  ans[i+j+1] = ans[i+j] + s1[i++];
    else    ans[i+j+1] = ans[i+j+2] = ans[i+j] + s1[i++], j++;
}


[fly]存在即是合理[/fly]
2013-05-20 13:22
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:0 
求差的过程可以加到循环中,O(n)应该蛮快了吧


[fly]存在即是合理[/fly]
2013-05-20 13:24
azzbcc
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:江西财经大学
等 级:贵宾
威 望:81
帖 子:3293
专家分:12919
注 册:2012-11-4
收藏
得分:0 
想当然了,额,不对。。。


[fly]存在即是合理[/fly]
2013-05-20 15:31
船长狙击手
Rank: 1
来 自:湖北
等 级:新手上路
帖 子:6
专家分:2
注 册:2011-11-27
收藏
得分:0 
回复 4楼 azzbcc
好厉害啊!我测试了下,果然是对的!而且结果也挺好!敢问大神是怎么分析这道题的??
2013-05-22 12:37
快速回复:今天参加笔试,遇到一题!求讲解!
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.015194 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved