Codeforces 1060D Social Circles 메시지 전환

문서 목록
  • 제의
  • 문제풀이
  • 제목의 뜻
    n명이 있는데 몇 개의 동그라미로 앉았다.모든 사람이 왼쪽에 l개의 빈 의자가 있고 오른쪽에 r개의 빈 의자가 있어야 한다고 요구한다.의자 몇 개라도 주세요.(각자 의자에 앉을 필요가 있다) n명이 있고 몇 개의 동그라미로 앉는다.ewline 각자 왼쪽에 l개의 빈 의자가 있고 오른쪽에 r개의 빈 의자가 있어야 합니다.ewline 의자 적어도 몇 개 주세요.(각자 의자에 앉을 필요가 있다) n명이 있고 몇 개의 동그라미로 앉는다.모든 사람이 왼쪽에 l개의 빈 의자가 있고 오른쪽에 r개의 빈 의자가 있어야 한다고 요구한다.의자 몇 개라도 주세요.(각자 의자 하나씩 앉아야 한다)
    문제풀이
    아주 재미있는 문제인데, 당연히 큰 놈한테 가볍게 떨어졌지.l,rl,rl,r 두 수조를 각각 정렬하여 n+∑i = 1 n max⁡(l[i],r[i]) n+\sum 출력{i=1}^{n}\max(l[i],r[i]) n+∑i=1n​max(l[i],r[i]). 그리고 왜.어떤 l l l l 은 어떤 r r r 와 일치 할 수 있다. 일치 한 결과 중간 작은 것 은 약속 이 취소 되고 큰 것 만 남았다.그러면 분명히 가장 좋은 일치는 가장 작은 lll와 가장 작은 rrr가 일치하는 것으로 추정된다.몇 개의 바퀴에 앉는 것을 주의하십시오. 모든 사람은 당연히 자신과 일치할 가능성이 있습니다.내가 있는 룸에 오렌지 깡패가 신선 장지혁한테 걸렸어.나는 그의 코드를 보았다.푸!안 켰어 long long!이런 실수는 정말 내가 웃었다. 오렌지색 사나이도 저지를 수 있는 실수이니 모두들 반드시 주의해야 한다.
    typedef long long ll;
    const int yuzu=1e5;
    typedef int fuko[yuzu|10];
    fuko l,r;
    int main(){
      int i,n=read();
      for (i=1;i<=n;++i) l[i]=read(),r[i]=read();
      sort(l+1,l+n+1),sort(r+1,r+n+1);
      ll llx=n;
      for (i=1;i<=n;++i) llx+=max(l[i],r[i]);
      cout<<llx<<endl;
    }
    

    감사합니다.

    좋은 웹페이지 즐겨찾기