JustDoIt521 2016-04-20 18:16 采纳率: 36.4%
浏览 1357

Acm 一道数据结构的问题,求思路,不求代码。

假设我有两数组,分别有n1 n2个数据(每组数据都不相同)。我要两个数组中各取一个相加,有n1乘n2种结果,从小到大排,取前n个。(如果n1 n2 特别大怎么算),求大神教我。

  • 写回答

5条回答

  • threenewbee 2016-04-20 21:33
    关注

    首先将n1 n2按照从小到大的顺序排成两列
    最小的肯定是n1[0]+n2[0](下面简写,只用下标,比如n1[0]+n2[0]记作0,0)
    稍微大一点的要么是1,0要么是0,1
    如果是1,0,那么再大一点的,要么是1,1,要么是2,0
    如果是0,1,那么再大一点的,要么是0,2,要么是1,1
    也就是前一个最小值的下标左右各加1这两种可能之一
    按照这个顺序找。

    评论

报告相同问题?

悬赏问题

  • ¥15 #MATLAB仿真#车辆换道路径规划
  • ¥15 java 操作 elasticsearch 8.1 实现 索引的重建
  • ¥15 数据可视化Python
  • ¥15 要给毕业设计添加扫码登录的功能!!有偿
  • ¥15 kafka 分区副本增加会导致消息丢失或者不可用吗?
  • ¥15 微信公众号自制会员卡没有收款渠道啊
  • ¥15 stable diffusion
  • ¥100 Jenkins自动化部署—悬赏100元
  • ¥15 关于#python#的问题:求帮写python代码
  • ¥20 MATLAB画图图形出现上下震荡的线条