[프로그래머스 | 파이썬 / 자바스크립트] 과일 장수(연습문제/ level 1)

2023. 3. 5. 11:29·Problem Solving/프로그래머스
반응형
문제

https://school.programmers.co.kr/learn/courses/30/lessons/135808 

 

프로그래머스

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

programmers.co.kr

 

 

🐍파이썬
def solution(k, m, score):
    answer = 0
    arr = []
    score.sort(reverse = True)
    for i in range(0, len(score), m):
        arr = score[i:i+m]
        if len(arr) == m:
            answer += min(arr) * m
    return answer
더보기

def solution(k, m, score):
    answer = 0
    score.sort(reverse = True)
    for i in range(1, len(score)//m + 1):	#1부터~(전체 배열 길이//m개)까지만 반복
        answer += score[m * i - 1] * m	#m개씩 묶은 배열의 가장 마지막 원소(각 배열에서 가장 작은 원소) * m개
    return answer
더보기

 

 

다른 풀이 방법

def solution(k, m, score):
    return sum(sorted(score)[len(score)%m::m])*m

 score 배열의 시작 인덱스를 (전체 배열의 길이 % m)으로 정함으로써 m개로 묶이지 못한 작은 수들은 카운팅에 포함되지 않도록 하였다. 이후 배열의 끝까지 m씩 인덱스를 건너뛰며 리스트를 만들고 그 리스트의 합을 m과 곱해 답을 구했다. 

 

 

🐥자바스크립트
function solution(k, m, score) {
    var answer = 0;
    apple = score.sort((a, b) => b - a)	//내림차순 정렬
    let i = 0
    while(true){
        if(apple.slice(i, i + m).length < m){	//m개 이상으로 자를 수 없을 때 반복문 종료
            return answer;
        }
        answer += apple.slice(i, i + m).at(-1) * m	//m개씩 자른 배열의 맨 마지막 원소(가장 작은 원소) * m
        i += m	//인덱스 m만큼 건너뛰기
    }
}

❓ at()

  • 정수 값을 받아, 배열에서 해당 값에 해당하는 인덱스의 요소를 반환하는 메서드.
  • 양수와 음수 모두 지정할 수 있고, 음수 값의 경우 배열의 뒤에서부터 인덱스를 센다.

 

다른 풀이 방법

function solution(k, m, score) {
    let answer = 0;
    //오름차순 정렬 후 m개로 묶이지 않는 나머지를 잘라냄
    const sortedScore = score.slice().sort((a, b) => a - b).slice(score.length % m);
    for (let i = 0; i < sortedScore.length; i += m) {
        answer += sortedScore[i] * m;
    }
    return answer;
}

💡 slice()

객체 참조를 새 배열로 복사, 얕은 복사이며 기존 배열을 대체하지 않는다.

 

 

 

 

 

 

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

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

[프로그래머스 | 파이썬 / 자바스크립트] 롤케이크 자르기(연습문제/ level 2)  (0) 2023.03.11
[프로그래머스 | 파이썬 / 자바스크립트] 영어가 싫어요(코딩테스트 입문/ level 0)  (0) 2023.03.10
[프로그래머스 | 파이썬 / 자바스크립트] 오픈채팅방(2019 KAKAO BLIND RECRUITMENT/ level 2)  (2) 2023.03.06
[프로그래머스 | 파이썬] 더 맵게(힙(Heap)/ level 2)  (0) 2023.03.03
[프로그래머스 | 파이썬 / 자바스크립트] 주차 요금 계산(2022 KAKAO BLIND RECRUITMENT/ level 2)  (0) 2023.03.03
[프로그래머스 | 파이썬 / 자바스크립트] 대충 만든 자판(연습문제/ level 1)  (0) 2023.02.28
'Problem Solving/프로그래머스' 카테고리의 다른 글
  • [프로그래머스 | 파이썬 / 자바스크립트] 영어가 싫어요(코딩테스트 입문/ level 0)
  • [프로그래머스 | 파이썬 / 자바스크립트] 오픈채팅방(2019 KAKAO BLIND RECRUITMENT/ level 2)
  • [프로그래머스 | 파이썬] 더 맵게(힙(Heap)/ level 2)
  • [프로그래머스 | 파이썬 / 자바스크립트] 주차 요금 계산(2022 KAKAO BLIND RECRUITMENT/ level 2)
청량리 물냉면
청량리 물냉면
프로그래밍 공부를 하고 있습니다. 공부 내용 정리 겸 정보 공유를 목적으로 합니다.
    반응형
  • 청량리 물냉면
    노력중인 블로그
    청량리 물냉면
  • 전체
    오늘
    어제
    • 분류 전체보기 N
      • 프로그래밍 N
        • Programming
        • C | C++
        • Java N
        • Python
      • 웹 프로그래밍
        • HTML | CSS
        • JavaScript | TypeScript
        • React
        • Vue.js
        • Next.js
        • Spring & Spring Boot
        • JSP & Servlet
        • DB
      • 웹 프로젝트
        • 웹 프로젝트
        • 🥨스낵몰
        • 👨‍👨‍👧‍👧소셜 가계부
        • 🌜꿈 일기장
        • 🔮포트폴리오 사이트
        • 🏃‍♂️팀 프로젝트: 일정관리 프로그램
        • 📈팀 프로젝트: AI기반 주식 분석 플랫폼
        • 😺Just Meow It: 고양이의 조언
      • 앱 프로그래밍
        • Flutter
        • Kotlin
      • Problem Solving
        • 백준
        • 프로그래머스
        • SWEA
      • Computer Science
        • 알고리즘
        • 컴퓨터 네트워크
        • 이산수학
      • Developer
        • 후기
        • 자료정리
        • 취업 | 취준
        • 웹개발 교육 프로그램
        • TIL
  • 블로그 메뉴

    • 홈
    • Github
  • 공지사항

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

  • 태그

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

  • hELLO· Designed By정상우.v4.10.3
청량리 물냉면
[프로그래머스 | 파이썬 / 자바스크립트] 과일 장수(연습문제/ level 1)
상단으로

티스토리툴바