[프로그래머스 | 파이썬] H-Index(정렬/ level 2)

2022. 12. 30. 21:28·Problem Solving/프로그래머스
반응형
문제

https://school.programmers.co.kr/learn/courses/30/lessons/42747#fn1

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

 

 

코드
def solution(citations):
    answer = 0
    citations.sort()
    for i in range(1, len(citations)+1):
        hindex = citations[-i]
        if hindex >= i:
            answer = i
    return answer

코드 참고: https://inistory.tistory.com/139

 

[프로그래머스] H-Index (Python)

1. 문제 설명 문제 링크 입력: 어떤 과학자의 논문 n편의 인용된 횟수를 담은 리스트 [3, 0, 6, 1, 5] 출력: h번이상 인용된 논문이 h편이상 인용된 경우 중에 h의 최댓값 찾기 3 2. 코드 def solution(citation

inistory.tistory.com

 

 

코드 설명
H-Idex: h개의 논문이 적어도 h개의 인용을 갖도록 하는 가장 큰 수 h
H-Idex 구하는 방법: f(리스트의 원소)의 값을 내림차순 정렬 -> f가 위치(인덱스)보다 크거나 같은 마지막 위치를 찾는다.

출처: 위키피디아 (https://en.wikipedia.org/wiki/H-index)

 

타 블로그를 참고하고서도 코드가 이해되지 않았는데(H-Index 원리를 이해하지 못함) 위키피디아를 보고 감이 잡혔다.

코드 구동 방식은 다음과 같다.

 

1️⃣ 리스트를 오름차순 정렬한다.

2️⃣ 1부터 시작하는 인덱스를 지정하기 위해 for문은 1부터 시작한다. 인덱스가 1부터 시작하므로 for문의 종료지점에는 +1을 붙여주어야 한다.

3️⃣ 오름차순 정렬된 원소의 [-1]번째 원소부터 인덱스와 비교한다. 즉, 가장 큰 원소부터 인덱스 1을 지정해준다.

4️⃣ 만약 인덱스(위치)보다 리스트의 원소(f)가 크거나 같다면 해당 인덱스 값을 answer에 대입한다.

5️⃣ for문을 통해 위 1️⃣ ~ 4️⃣를 반복해 f가 위치보다 크거나 같은 마지막 위치를 찾는다.

 

 

 

다른 풀이 방법
def solution(citations):
    citations.sort(reverse=True)
    answer = max(map(min, enumerate(citations, start=1)))
    return answer

enumerate(): 인덱스와 리스트의 원소를 사전 형태로 출력하는 함수. 위 풀이에서는 start = 1을 통해 인덱스의 시작을 1로 지정하였다.

 

❓enumerate 참고 블로그

https://www.daleseo.com/python-enumerate/

 

파이썬의 enumerate() 내장 함수로 for 루프 돌리기

Engineering Blog by Dale Seo

www.daleseo.com

 

문제 해석은 아래 블로그의 풀이 해석을 참고했다.

https://ssuamje.tistory.com/47

 

(프로그래머스, 파이썬) 정렬 : [K번째 수, H-index, 가장 큰 수]

레벨 2부터 벽을 느끼는 나.. 역시 물 실버였다. 코딩테스트 연습 - 정렬 - K번째 수 -내 코드- def solution(array, commands): answer = [] for cmd in commands: i, j, k = cmd array_processed = sorted(array[i-1:j]) answer.append(arr

ssuamje.tistory.com

 

 

반응형
저작자표시 비영리 변경금지 (새창열림)

'Problem Solving > 프로그래머스' 카테고리의 다른 글

[프로그래머스 | 파이썬 / 자바스크립트] 주사위의 개수(코딩테스트 입문/ level 0)  (0) 2023.02.19
[프로그래머스 | 파이썬 / 자바스크립트] 짝수 홀수 개수(코딩테스트 입문/ level 0)  (0) 2023.02.19
[프로그래머스 | 파이썬] 캐시(2018 KAKAO BLIND RECRUITMENT/ level 2)  (0) 2023.01.01
[프로그래머스 | 파이썬] 비밀지도 (2018 KAKAO BLIND RECRUITMENT/ level 1)  (0) 2022.12.28
[프로그래머스 | 파이썬] 카펫 (완전탐색 / level 2)  (0) 2022.12.28
[프로그래머스] 연습문제 "같은 숫자는 싫어"(파이썬)  (0) 2022.05.14
'Problem Solving/프로그래머스' 카테고리의 다른 글
  • [프로그래머스 | 파이썬 / 자바스크립트] 짝수 홀수 개수(코딩테스트 입문/ level 0)
  • [프로그래머스 | 파이썬] 캐시(2018 KAKAO BLIND RECRUITMENT/ level 2)
  • [프로그래머스 | 파이썬] 비밀지도 (2018 KAKAO BLIND RECRUITMENT/ level 1)
  • [프로그래머스 | 파이썬] 카펫 (완전탐색 / level 2)
청량리 물냉면
청량리 물냉면
프로그래밍 공부를 하고 있습니다. 공부 내용 정리 겸 정보 공유를 목적으로 합니다.
    반응형
  • 청량리 물냉면
    노력중인 블로그
    청량리 물냉면
  • 전체
    오늘
    어제
    • 분류 전체보기 (505)
      • 프로그래밍 (41)
        • Programming (1)
        • C | C++ (6)
        • Java (28)
        • Python (5)
      • 웹 프로그래밍 (108)
        • HTML | CSS (5)
        • JavaScript | TypeScript (41)
        • React (25)
        • Vue.js (0)
        • Next.js (18)
        • Spring & Spring Boot (13)
        • JSP & Servlet (1)
        • DB (4)
      • 웹 프로젝트 (77)
        • 웹 프로젝트 (22)
        • 🥨스낵몰 (3)
        • 👨‍👨‍👧‍👧소셜 가계부 (26)
        • 🌜꿈 일기장 (11)
        • 🔮포트폴리오 사이트 (11)
        • 🏃‍♂️팀 프로젝트: 일정관리 프로그램 (0)
        • 📈팀 프로젝트: AI기반 주식 분석 플랫폼 (0)
        • 😺Just Meow It: 조언 사이트 (2)
        • 📕Workly: 교대근무 다이어리 (1)
      • 앱 프로그래밍 (26)
        • Flutter (24)
        • Kotlin (2)
      • Problem Solving (166)
        • 백준 (52)
        • 프로그래머스 (79)
        • SWEA (29)
      • Computer Science (40)
        • 알고리즘 (14)
        • 컴퓨터 네트워크 (18)
        • 이산수학 (8)
      • Developer (47)
        • 후기 (4)
        • 자료정리 (4)
        • 취업 | 취준 (9)
        • SSAFY (1)
        • 웹개발 교육 프로그램 (9)
        • TIL (20)
  • 블로그 메뉴

    • 홈
    • Github
  • 공지사항

    • 프로그래밍 공부 중😊
  • 인기 글

  • 태그

    Next.js
    블로그 제작
    d3
    컴퓨터네트워크
    AWS
    공식문서
    React
    자바스크립트
    백준
    mysql
    알고리즘
    bfs
    구현
    포트폴리오
    프로젝트
    플러터
    프로그래머스
    파이썬
    SWEA
    Til
    ZeroCho
    클론 프로젝트
    웹사이트
    spring boot
    Jiraynor Programming
    타입스크립트
    리액트
    강의내용정리
    자바
    뉴렉처
  • 최근 글

  • hELLO· Designed By정상우.v4.10.3
청량리 물냉면
[프로그래머스 | 파이썬] H-Index(정렬/ level 2)
상단으로

티스토리툴바