P1392 取数

传送门:取数

如若你看完题解后,仍有问题,欢迎评论

首先说一下 我首先想到的思路 ( 20%通过率 ):通过dfs , 将所有的情况放入priority_queue中(greater<int>),维持堆中的数据为k个    ->   TLE

代码:

#include<bits/stdc++.h>
using namespace std;
int n, m, k;
const int N = 810;
int a[N][N];
priority_queue<int> heap;
void dfs(int i  , int sum)
{
    if (i == n + 1) {
        if (heap.size() == k && sum < heap.top()) {
            heap.pop(); heap.push(sum);
        }
        else if (heap.size() < k)heap.push(sum);
        return;
    }
    for (int k = 1; k <= m; k++)
    {
        dfs(i + 1, sum + a[i][k]);
    }
}
int main()
{
    scanf("%d%d%d", &n, &m, &k);
    for (int i = 1; i <= n; i++)
        for (int j = 1; j <= m; j++)
            scanf("%d", &a[i][j]);
    dfs(1, 0);
    
    vector<int> res;
    while (heap.size())
    {
        res.push_back(heap.top()); heap.pop();
    }
    reverse(res.begin(), res.end());
    for (auto e : res)
        printf("%d ", e);
    return 0;
}

错误代码的时间复杂度分析: n * m * klongk (建堆 + 遍历整个矩阵)> 10 ^ 8     因此TLE

优化方法:

时间复杂度分析:n * ( mlongm ( 排序 ) +  klongk ( 调和级数 ) ) == nmlongm + nklongk = 10 ^ 6 (约等于 )  < 10 ^ 8   可以AC

AC Code:

#include<bits/stdc++.h>
using namespace std;
const int N = 810;
int a[N] , b[N];
int n , m , k;
int x,y;
priority_queue<int> heap;
int main()
{
    scanf("%d%d%d",&n,&m,&k);
    heap.push(0);
    for( int i = 1 ; i <= n; i++)
    {
        x = 0; y = 0;
        while( heap.size()) b[++y] = heap.top(),heap.pop();
        for( int j= 1 ; j<= m;j++)scanf("%d",&a[j]);
        sort( a + 1 , a + m + 1 );
        for( int l = 1 ; l <= m;l++)
        {
            for( int r = y ; r ; r--)
            {
                if( x < k )heap.push( a[l] + b[r] ),x++;
                else if( heap.top() < a[l] + b[r] )break;
                else heap.pop(),heap.push(a[l] + b[r] );
            }
        }
    }
    vector<int> res;
    while( heap.size())
    {
        res.push_back(heap.top());
        heap.pop();
    }
    reverse( res.begin(),res.end());
    for( auto e : res  )
    {
        printf("%d ",e );
    }
    return 0;
}

相关推荐

  1. P1392

    2024-07-11 03:24:02       54 阅读
  2. P1005 [NOIP2007 提高组] 矩阵游戏

    2024-07-11 03:24:02       36 阅读
  3. luogu P1352 没有上司的舞会 详解

    2024-07-11 03:24:02       44 阅读
  4. P1643 完美 题解

    2024-07-11 03:24:02       52 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-07-11 03:24:02       67 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-07-11 03:24:02       72 阅读
  3. 在Django里面运行非项目文件

    2024-07-11 03:24:02       58 阅读
  4. Python语言-面向对象

    2024-07-11 03:24:02       69 阅读

热门阅读

  1. Jmeter进阶-接口自动化

    2024-07-11 03:24:02       16 阅读
  2. 在 Ubuntu 上玩转 WordPress

    2024-07-11 03:24:02       24 阅读
  3. Redis 数据过期及淘汰策略

    2024-07-11 03:24:02       21 阅读
  4. VSCode 推荐插件列表(都安装到Remote SSH上)

    2024-07-11 03:24:02       18 阅读
  5. bug——多重定义

    2024-07-11 03:24:02       23 阅读
  6. Tkinter 部件使用教程

    2024-07-11 03:24:02       20 阅读
  7. ASPICE评估是汽车软件质量的可靠保障

    2024-07-11 03:24:02       21 阅读
  8. AI绘画好学吗?解锁创意无限的艺术新纪元

    2024-07-11 03:24:02       24 阅读
  9. P1255 数楼梯【递推+大数】

    2024-07-11 03:24:02       20 阅读
  10. 中断相关知识

    2024-07-11 03:24:02       21 阅读
  11. 春风得意特斯拉(六)

    2024-07-11 03:24:02       22 阅读
  12. C语言10 函数

    2024-07-11 03:24:02       21 阅读