m0_74153183 2022-12-24 23:32 采纳率: 95.5%
浏览 32
已结题

我这一题TLE应该如何解决?

问题遇到的现象和发生背景

img

遇到的现象和发生背景,请写出第一个错误信息

img


我用了快速排序为什么还是超时,应该怎么解决呢?

用代码块功能插入代码,请勿粘贴截图。 不用代码块回答率下降 50%
#include<stdio.h>
int a[1000000];
void quicksort(int left, int right)
{
    int i, j, t, temp;
    temp = a[left];
    i = left;
    j = right;
    while (i != j)
    {
        while (a[j] >= temp && i < j)
            j--;
        while (a[j] >= temp && i < j)
            i++;
        if (i < j)
        {
            t = a[i];
            a[i] = a[j];
            a[j] = t;
        }
    }
    a[left] = a[i];
    a[i] = temp;
    quicksort(left, i - 1);
    quicksort(i + 1, right);
    return;
}
int main()
{
    int N, B,i,j,sum=0,s=0;
    scanf("%d%d", &N, &B);
    j = N;
    for (i = 1; i <= N; i++)
    {
        scanf("%d", &a[i]);
    }
    quicksort(1, N);
    while (a[j]!=0)
    {
        sum += a[j--];
        s++;
        if (sum >= B)
        {
            printf("%d",s-1);
            break;
        }
    }
    return 0;
}

运行结果及详细报错内容

TLE

我的解答思路和尝试过的方法,不写自己思路的,回答率下降 60%

我用了快速排序,但是还是超时了,如果不想让他超时,应该怎么办呢?

我想要达到的结果,如果你需要快速回答,请尝试 “付费悬赏”
  • 写回答

1条回答 默认 最新

  • hackferances 2022-12-25 11:54
    关注

    这题应该要用二分法

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 1月8日
  • 已采纳回答 12月31日
  • 创建了问题 12月24日

悬赏问题

  • ¥20 怎么用dlib库的算法识别小麦病虫害
  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
  • ¥15 java写代码遇到问题,求帮助
  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算