overlordLSY 2018-11-20 10:28 采纳率: 100%
浏览 884
已采纳

算法题 - 输出数组中数字两两相加的所有结果,要求时间复杂度o(n)

比如数组{7,5,3,4},输出12,10,11,8,9,7
时间复杂度o(n),所以不能用循环嵌套

  • 写回答

2条回答 默认 最新

  • threenewbee 2018-11-20 14:11
    关注

    时间复杂度O(n)绝对不可能,起码O(n^2)
    不用循环或者只用一个循环是可以的。

    #include "stdio.h"
    
    void foo(int * arr, int n, int acc)
    {
        if (acc == n * n) return;
        if (acc / n > acc % n)
            printf("%d ", arr[acc / n] + arr[acc % n]);
        foo(arr, n, acc + 1);
    }
    
    int main()
    {
        int arr[] = { 7, 5, 3, 4 };
        foo(arr, 4, 0);
        return 0;
    }
    

    图片说明

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥30 这是哪个作者做的宝宝起名网站
  • ¥60 版本过低apk如何修改可以兼容新的安卓系统
  • ¥25 由IPR导致的DRIVER_POWER_STATE_FAILURE蓝屏
  • ¥50 有数据,怎么建立模型求影响全要素生产率的因素
  • ¥50 有数据,怎么用matlab求全要素生产率
  • ¥15 TI的insta-spin例程
  • ¥15 完成下列问题完成下列问题
  • ¥15 C#算法问题, 不知道怎么处理这个数据的转换
  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!