HihoCoder - 1722 最小差值 (set容器)

给定N个数组,每个数组都包含M个整数。  

现在你被要求从每个数组中选出一个数,总共N个数,然后求出其中最大与最小的差值。  

在MN种选法中,差值最小是多少?

Input

第一行包含两个整数N和M。  

以下N行,每行包含M个整数。  

对于50%的数据,1 ≤ N × M ≤ 10000  

对于100%的数据,1 ≤ N × M ≤ 200000 0 ≤ 每个整数 ≤ 1000000

Output

最小的差值

Sample Input
3 3  
8 1 6      
3 5 7  
4 9 2
Sample Output
2

解:用n个优先队列存数字,(优先队列起到了由小到大排序的作用),然后每个队列中取出最小的全部存入set容器中(set容器起到了自动由小到大排序的功能,而且能找到第1个和最后1个),然后输出最大值-最小值和 ans比较 取小值 ,然后把其中最小的取出来,把那个最小值所对应的那个队列的次小值取出,放入set容器中 再次比较输出,直到某一个队列中没有值为止

#include<stdio.h>
#include<algorithm>
#include<string.h>
#include<iostream>
#include<math.h>
#include<queue>
#include<map>
#include<vector>
#include<set>
using namespace std;
#define inf 0x3f3f3f3f
#define ll long long
struct node
{
    int x,id;
    friend bool operator <(node n1,node n2)
    {
        return n2.x<n1.x;
    }
};
priority_queue<node>q[200010];//优先队列
multiset<node>mm;//multiset容器和set不同的是能存重复值
int n,m;
int main()
{
    int a;
    int ans=inf;
    node k,k1,k2;
    scanf("%d%d",&n,&m);
    for(int i=1;i<=n;i++)
        for(int j=1;j<=m;j++)
    {
        scanf("%d",&a);
        k.x=a;
        k.id=i;
        q[i].push(k);
    }
    for(int i=1;i<=n;i++)
    {
        k=q[i].top();
        q[i].pop();
        mm.insert(k);//把最小值放入set容器中
    }
    multiset<node>::iterator it;//迭代器
    while(1)
    {
        it=mm.begin();//最大值
        k1=*it;
        it=mm.end();//最后面的值,指向空
        it--;//找到最末值,即最小值
        k2=*it;
        ans=min(ans,k1.x-k2.x);
        mm.erase(it);//最小值取出
        int id=k2.id;
        if(!q[id].empty())
        {
           k1=q[id].top();
           q[id].pop();
           mm.insert(k1);//放入次小值
        }
        else   break;

    }
    printf("%d\n",ans);
}



  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值