83472024-01-14 21:24:47zoliMekk Mester munkái (50 pont)cpp17Hibás válasz 0/5079ms6300 KiB
#include <iostream>
#include <algorithm>
using namespace std;
struct munka
{
    int sorsz,k,v;
}a[100001];
int c[100001],b[100001],n,h,db1=0,db2=0;
void be()
{
    cin>>n>>h;
    for(int i=1;i<=n;i++)
    {
        a[i].sorsz=i;
        cin>>a[i].k>>a[i].v;
    }
}
bool hasonlit(munka x, munka y)
{
    return x.v<y.v;  /// esetleg egyenlo vegzodeskor nezni a kezdtete vagy sorszamot
}
void rendez()
{
    sort(a+1,a+n+1,hasonlit);
}
void kiir()
{
    for (int i=1;i<=n;i++) cout<<a[i].sorsz<<" "<<a[i].k<<"-"<<a[i].v<<endl;
}
int main()
{
    be();
    //kiir();
    rendez();
    //kiir();
    db1++;
    b[1]=a[1].sorsz;
    if(n>=2)  /// ha van két munka
    {
        db2++;
        c[1]=a[2].sorsz;
    }
    for(int i=3;i<=n;i++)//vegig a munkakon
        if(a[i].k>min(a[b[db1]].v,a[c[db2]].v))
            if(a[b[db1]].v<a[c[db2]].v)
            {
               db1++; b[db1]=a[i].sorsz;
            }
            else
            {
                db2++; c[db2]=a[i].sorsz;
            }
    cout<<db1<<" "<<db2<<endl;
    for(int i=1;i<=db1;i++)  cout<<b[i]<<" ";
    cout<<endl;
    for(int i=1;i<=db2;i++)  cout<<c[i]<<" ";
    cout<<endl;
    return 0;
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
base0/50
1Hibás válasz0/03ms1924 KiB
2Hibás válasz0/08ms2400 KiB
3Hibás válasz0/13ms2296 KiB
4Hibás válasz0/13ms2508 KiB
5Hibás válasz0/23ms2744 KiB
6Hibás válasz0/23ms2976 KiB
7Hibás válasz0/23ms3016 KiB
8Hibás válasz0/23ms3152 KiB
9Hibás válasz0/33ms3512 KiB
10Hibás válasz0/13ms3412 KiB
11Hibás válasz0/13ms3424 KiB
12Hibás válasz0/24ms3552 KiB
13Hibás válasz0/23ms3636 KiB
14Hibás válasz0/23ms3636 KiB
15Hibás válasz0/23ms3780 KiB
16Hibás válasz0/33ms3756 KiB
17Hibás válasz0/279ms6204 KiB
18Hibás válasz0/279ms6156 KiB
19Hibás válasz0/479ms6156 KiB
20Hibás válasz0/479ms6160 KiB
21Hibás válasz0/479ms6220 KiB
22Hibás válasz0/479ms6216 KiB
23Hibás válasz0/479ms6300 KiB