모바일 오유 바로가기
http://m.todayhumor.co.kr
분류 게시판
베스트
  • 베스트오브베스트
  • 베스트
  • 오늘의베스트
  • 유머
  • 유머자료
  • 유머글
  • 이야기
  • 자유
  • 고민
  • 연애
  • 결혼생활
  • 좋은글
  • 자랑
  • 공포
  • 멘붕
  • 사이다
  • 군대
  • 밀리터리
  • 미스터리
  • 술한잔
  • 오늘있잖아요
  • 투표인증
  • 새해
  • 이슈
  • 시사
  • 시사아카이브
  • 사회면
  • 사건사고
  • 생활
  • 패션
  • 패션착샷
  • 아동패션착샷
  • 뷰티
  • 인테리어
  • DIY
  • 요리
  • 커피&차
  • 육아
  • 법률
  • 동물
  • 지식
  • 취업정보
  • 식물
  • 다이어트
  • 의료
  • 영어
  • 맛집
  • 추천사이트
  • 해외직구
  • 취미
  • 사진
  • 사진강좌
  • 카메라
  • 만화
  • 애니메이션
  • 포니
  • 자전거
  • 자동차
  • 여행
  • 바이크
  • 민물낚시
  • 바다낚시
  • 장난감
  • 그림판
  • 학술
  • 경제
  • 역사
  • 예술
  • 과학
  • 철학
  • 심리학
  • 방송연예
  • 연예
  • 음악
  • 음악찾기
  • 악기
  • 음향기기
  • 영화
  • 다큐멘터리
  • 국내드라마
  • 해외드라마
  • 예능
  • 팟케스트
  • 방송프로그램
  • 무한도전
  • 더지니어스
  • 개그콘서트
  • 런닝맨
  • 나가수
  • 디지털
  • 컴퓨터
  • 프로그래머
  • IT
  • 안티바이러스
  • 애플
  • 안드로이드
  • 스마트폰
  • 윈도우폰
  • 심비안
  • 스포츠
  • 스포츠
  • 축구
  • 야구
  • 농구
  • 바둑
  • 야구팀
  • 삼성
  • 두산
  • NC
  • 넥센
  • 한화
  • SK
  • 기아
  • 롯데
  • LG
  • KT
  • 메이저리그
  • 일본프로야구리그
  • 게임1
  • 플래시게임
  • 게임토론방
  • 엑스박스
  • 플레이스테이션
  • 닌텐도
  • 모바일게임
  • 게임2
  • 던전앤파이터
  • 마비노기
  • 마비노기영웅전
  • 하스스톤
  • 히어로즈오브더스톰
  • gta5
  • 디아블로
  • 디아블로2
  • 피파온라인2
  • 피파온라인3
  • 워크래프트
  • 월드오브워크래프트
  • 밀리언아서
  • 월드오브탱크
  • 블레이드앤소울
  • 검은사막
  • 스타크래프트
  • 스타크래프트2
  • 베틀필드3
  • 마인크래프트
  • 데이즈
  • 문명
  • 서든어택
  • 테라
  • 아이온
  • 심시티5
  • 프리스타일풋볼
  • 스페셜포스
  • 사이퍼즈
  • 도타2
  • 메이플스토리1
  • 메이플스토리2
  • 오버워치
  • 오버워치그룹모집
  • 포켓몬고
  • 파이널판타지14
  • 배틀그라운드
  • 기타
  • 종교
  • 단어장
  • 자료창고
  • 운영
  • 공지사항
  • 오유운영
  • 게시판신청
  • 보류
  • 임시게시판
  • 메르스
  • 세월호
  • 원전사고
  • 2016리오올림픽
  • 2018평창올림픽
  • 코로나19
  • 2020도쿄올림픽
  • 게시판찾기
  • 오유인페이지
    개인차단 상태
    할말이있어님의
    개인페이지입니다
    가입 : 12-10-14
    방문 : 1004회
    닉네임변경 이력
    회원차단
    회원차단해제
    게시물ID : programmer_4830
    작성자 : 할말이있어
    추천 : 0
    조회수 : 442
    IP : 125.177.***.135
    댓글 : 8개
    등록시간 : 2014/08/04 23:00:03
    http://todayhumor.com/?programmer_4830 모바일
    정렬되지 않은 쌍의 개수
    수열 a(1), a(2), ..., a(n) <span style="font-size:9pt;line-height:1.5;">에서 정렬되지 않은 쌍이란 a(j) > a(k) (j < k) 를 말합니다. 모든 정렬되지 않은 쌍의 개수를 어떻게 빠르게 셀 수 있을까요.</span> <div><div><br></div> <div><span style="font-size:9pt;line-height:1.5;">각각의 a(k) 에 대해 a(1)~a(k-1) 을 모두 살펴보아서 자신보다 크면 세는 방법이 있습니다. 총 n*(n-1)/2 번의 비교가 이루어 지겠군요. 이 방법은 n 이 십만 정도로 커지면 너무 오래 걸립니다.</span></div> <div><span style="font-size:9pt;line-height:1.5;"><br></span></div> <div>자신보다 앞의 결과를 저장한 후 사용하여 시간을 단축하기 위해 관계를 찾아봅니다.</div> <div><br></div> <div>d(k) 를 a(1)~a(k-1) 중 a(k) 보다 큰 것들의 개수라고 합시다.  물론 d(1)=0 입니다. </div></div> <div>d(j, k) 를 a(j)~a(k-1) 중 a(k) 보다 큰 것들의 개수라고 합시다. d(k) = d(1, k) 가 되겠군요.</div> <div><span style="font-size:9pt;line-height:1.5;">문제의 답은 d(1) + d(2) + ... + d(n) 이 되겠죠. 따라서 d(k)를 구하는 시간을 줄이는 것이 목표가 될 것입니다.</span></div> <div><br></div> <div>d(k) 에 대한 어떤 관계식을 생각해봅시다.</div> <div><br></div> <div>다음과 같은 것도 생각할 수 있겠죠.</div> <div>만약 어떤 j (j < k) 에 대해 a(j)==a(k) 라면 d(k) = d(j) + d(j,k) 가 되겠죠. a(1)~a(j-1) 중 a(k) 보다 큰 것들의 개수는 d(j) 이니까요.</div> <div>하지만 이는 만족스럽지 못합니다. 만약 수열 a 에 같은 수가 하나도 없다면 전혀 관계식을 써먹을 수 없기 때문이죠. 있다고 해도 k 와 j 가 아주 멀리 있다면 j를 찾기 위해 걸리는 시간이나 a(1)~a(k-1)을 모두 a(k)와 비교해 보는 시간이나 별로 다를 것이 없기 때문이기도 합니다.</div> <div><br></div> <div>그렇다면 어떤 j (j < k) 에 대해 a(j) > a(k) 일 때 d(k) 를 d(j)로 설명할 수 있다면 성공적이겠죠. 그러한 j 가 하나라도 있다면 관계식을 써먹을 수 있고 없다면 자동적으로 d(j) 는 0 이 되기 때문입니다. 더욱이 그러한 j는 꽤 많이 존재할텐데 왜냐면 무작위 수열일 경우에 자기보다 클 확률은 50프로이기 때문이죠. 따라서 그러한 j는 k와 아주 가까운데서 쉽게 찾을 수 있을겁니다.</div> <div>식은 다음과 같겠죠.</div> <div>d(k) = d(j, k) + d(j) + (a(1)~a(j) 중 a(k)보다 크고 a(j)보다 작은 것들의 개수)</div> <div>이는 d(j) 가 <span style="font-size:9pt;line-height:1.5;">a(1)~a(j) 중 a(j)보다 작은 것들의 개수는 세지 못했기 때문이죠.</span></div> <div>식이 추잡하네요. 식이 우아해지지 못하면 보통 망하더군요.</div> <div><br></div> <div>음 다른 방법을 생각해봅시다.</div> <div><br></div> <div>d(k)를 찾고 정렬을 한다면 d(k+1)는 이진탐색을 통해 쉽게 찾을 수 있겠죠.</div> <div>정렬에 걸리는 시간을 생각해봅시다. 항상 이미 정렬되어 있는 상태니까 새 원소를 제자리에 삽입하는 방법이 적당하겠죠.</div> <div>정렬에 걸리는 시간을 다 합치면 그냥 길이 n짜리 수열을 삽입정렬하는 시간이기 때문에 최악의 경우 O(n^2)이 되겠네요. 에라이; 이진탐색에 걸리는 시간 세지도 않았는데 이미 느낌이 별로 좋지 않군요.</div> <div><br></div> <div>분명 우아한 솔루션이 존재할거 같은 느낌인데.... (자살)</div> <div><br></div>

    이 게시물을 추천한 분들의 목록입니다.
    푸르딩딩:추천수 3이상 댓글은 배경색이 바뀝니다.
    (단,비공감수가 추천수의 1/3 초과시 해당없음)

    죄송합니다. 댓글 작성은 회원만 가능합니다.

    번호 제 목 이름 날짜 조회 추천
    56
    뭔가 뿌듯 [3] 할말이있어 14/10/26 22:51 46 2
    55
    Windows밀고 Ubuntu 깔고 싶은데요.. [5] 할말이있어 14/10/16 15:31 47 0
    54
    먹을것인가......... [3] 할말이있어 14/10/13 22:50 37 0
    53
    낙성대야식츄천좀 [1] 할말이있어 14/10/13 22:43 39 0
    52
    아아코딩하고싶다 [4] 할말이있어 14/10/13 21:36 35 1
    51
    공대생의 윤리란 무엇인가 (시험준비용) [1] 할말이있어 14/10/06 13:11 37 2
    50
    혈변 [4] 할말이있어 14/10/01 15:58 67 0
    49
    C++ sort() vs qsort() [5] 할말이있어 14/09/29 18:59 42 0
    48
    전기회로에서 [1] 할말이있어 14/09/28 18:00 31 0
    47
    C++ n 개 원소중에 모든 m 쌍 뽑기 [14] 할말이있어 14/09/21 23:18 17 0
    46
    전문연구요원 [8] 할말이있어 14/09/21 21:31 32 0
    45
    전문연구요원 [3] 할말이있어 14/09/21 21:30 41 0
    44
    페이스북 탈퇴한지 몇달되어가는데 할말이있어 14/09/20 13:17 45 1
    43
    잠은안오고 [4] 할말이있어 14/09/20 03:55 37 0
    42
    C++ map [5] 할말이있어 14/09/17 22:59 35 0
    41
    C++ [2] 할말이있어 14/09/17 22:33 43 0
    40
    흥미로운 문제 하나 [12] 할말이있어 14/09/15 22:43 41 0
    39
    ->[] ? [6] 할말이있어 14/09/13 21:32 46 0
    38
    C++ 무거운 return [12] 할말이있어 14/09/13 20:18 61 1
    37
    C++ vector [2] 할말이있어 14/09/13 16:22 43 0
    36
    간단한 질문 [3] 할말이있어 14/09/13 01:38 42 0
    35
    1:1 최적화 문제 [9] 할말이있어 14/09/09 16:27 79 0
    34
    java class return 하는 method [22] 할말이있어 14/09/08 22:55 26 1
    33
    소수 예술 [8] 할말이있어 14/09/03 22:53 93 13
    32
    제일짧은코드 [14] 할말이있어 14/09/02 00:52 61 1
    31
    탑알리;; [6] 할말이있어 14/08/18 18:53 266 0
    30
    시간여행을 위한 자료구조에 대해서... [3] 할말이있어 14/08/07 16:17 47 0
    29
    C++ class static variable 접근 [7] 할말이있어 14/08/07 14:08 37 0
    정렬되지 않은 쌍의 개수 [10] 할말이있어 14/08/04 23:00 31 0
    27
    수학 질문 [4] 할말이있어 14/08/04 22:22 50 2
    [1] [2] [3] [4]
    단축키 운영진에게 바란다(삭제요청/제안) 운영게 게시판신청 자료창고 보류 개인정보취급방침 청소년보호정책 모바일홈