[프로그래머스 | 파이썬 / 자바스크립트] 연속 부분 수열 합의 개수(연습문제/ level 2)

2023. 2. 28. 12:22·Problem Solving/프로그래머스
반응형
문제

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

 

프로그래머스

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

programmers.co.kr

 

 

🐍파이썬
def solution(elements):
    arr = [i for i in elements] #길이1
    arr.append(sum(elements))   #길이n
    for i in range(2, len(elements)):  #길이 2 ~ n-1개의 부분수열
        for j in range(len(elements)):
            hap = 0
            if i + j > len(elements):	#배열의 인덱스를 벗어날 경우
                hap += sum(elements[j:len(elements)])
                hap += sum(elements[0:(i + j)%len(elements)])
            else:
                hap += sum(elements[j:i+j])
            arr.append(hap)	#구한 합을 arr에 추가
    return len(set(arr))	#중복제거 후 출력
더보기
효율성 극악...

 

 

다른 풀이 방법

def solution(elements):
    ll = len(elements)
    res = set()
    for i in range(ll):
        ssum = elements[i]
        res.add(ssum)
        for j in range(i+1, i+ll):
            ssum += elements[j%ll]
            res.add(ssum)
    return len(res)

코드만 봤을 때는 이해하기 힘들어 각 반복문마다 변수의 값을 출력해 보았다.

def solution(elements):
    ll = len(elements)
    res = set()
    for i in range(ll):
        ssum = elements[i]  #원소 1개
        res.add(ssum)
        print(ssum)
        for j in range(i+1, i+ll):
            print(i, j, j%ll)
            ssum += elements[j%ll] 
            print(ssum)
            res.add(ssum)
    return len(res)

출력결과는 아래와 같다.

7	# i == 0, 원소 1개의 합
0 1 1	#i, j, i%ll
16	# i == 0부터 원소 2개의 합
0 2 2
17	# i == 0부터 원소 3개의 합
0 3 3
18	# i == 0부터 원소 4개의 합
0 4 4
22	# i == 0부터 원소 5개의 합
9	# i == 1, 원소 1개의 합
1 2 2
10	# i == 1부터 원소 2개의 합
1 3 3
11	# i == 1부터 원소 3개의 합
1 4 4
15	# i == 1부터 원소 4개의 합
1 5 0
22	# i == 1부터 원소 5개의 합
1	# i == 2, 원소 1개의 합
2 3 3
2
2 4 4
6
2 5 0
13
2 6 1
22
1	# i == 3, 원소 1개의 합
3 4 4
5
3 5 0
12
3 6 1
21
3 7 2
22
4	# i == 4, 원소 1개의 합
4 5 0
11
4 6 1
20
4 7 2
21
4 8 3
22

elements의 각 원소마다 연속되는 1개, 2개, 3개, 4개,...의 값을 구하여 set()에 add한 풀이이다.

 

 

🐥자바스크립트
function solution(elements) {
    var answer = 0;
    let eSet = new Set();
    for(let i = 0; i < elements.length; i++){
        answer = elements[i];
        eSet.add(answer);
        for(let j = i+1; j < i+elements.length; j++){
            answer += elements[j%elements.length];
            eSet.add(answer)
        }
    }
    return eSet.size;
}

위 파이썬 <다른 풀이 방법> 풀이를 자바스크립트 풀이로 구현하였다.

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

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

[프로그래머스 | 파이썬 / 자바스크립트] 주차 요금 계산(2022 KAKAO BLIND RECRUITMENT/ level 2)  (0) 2023.03.03
[프로그래머스 | 파이썬 / 자바스크립트] 대충 만든 자판(연습문제/ level 1)  (0) 2023.02.28
[프로그래머스 | 파이썬 / 자바스크립트] [1차] 뉴스 클러스터링(2018 KAKAO BLIND RECRUITMENT/ level 2)  (0) 2023.02.28
[프로그래머스 | 파이썬 / 자바스크립트] 이진수 더하기(코딩테스트 입문/ level 0)  (0) 2023.02.28
[프로그래머스 | 파이썬 / 자바스크립트] 유한소수 판별하기(코딩테스트 입문/ level 0)  (0) 2023.02.25
[프로그래머스 | 파이썬 / 자바스크립트] 대문자와 소문자(코딩테스트 입문/ level 0)  (0) 2023.02.25
'Problem Solving/프로그래머스' 카테고리의 다른 글
  • [프로그래머스 | 파이썬 / 자바스크립트] 대충 만든 자판(연습문제/ level 1)
  • [프로그래머스 | 파이썬 / 자바스크립트] [1차] 뉴스 클러스터링(2018 KAKAO BLIND RECRUITMENT/ level 2)
  • [프로그래머스 | 파이썬 / 자바스크립트] 이진수 더하기(코딩테스트 입문/ level 0)
  • [프로그래머스 | 파이썬 / 자바스크립트] 유한소수 판별하기(코딩테스트 입문/ level 0)
청량리 물냉면
청량리 물냉면
프로그래밍 공부를 하고 있습니다. 공부 내용 정리 겸 정보 공유를 목적으로 합니다.
    반응형
  • 청량리 물냉면
    노력중인 블로그
    청량리 물냉면
  • 전체
    오늘
    어제
    • 분류 전체보기
      • 프로그래밍
        • Programming
        • C | C++
        • Java
        • 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
  • 공지사항

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

  • 태그

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

  • hELLO· Designed By정상우.v4.10.3
청량리 물냉면
[프로그래머스 | 파이썬 / 자바스크립트] 연속 부분 수열 합의 개수(연습문제/ level 2)
상단으로

티스토리툴바