Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | |||||
3 | 4 | 5 | 6 | 7 | 8 | 9 |
10 | 11 | 12 | 13 | 14 | 15 | 16 |
17 | 18 | 19 | 20 | 21 | 22 | 23 |
24 | 25 | 26 | 27 | 28 | 29 | 30 |
31 |
Tags
- modbus
- javascript
- configfile
- 알고리즘
- Stack
- 완전탐색
- Two Pointer
- algorhtim
- dfs
- PCCP
- javascirpt
- frontend
- 42587
- 코딩테스트
- Algorithm
- React
- 1844
- 파이썬
- summerwintercoding
- 좌표이동
- pymodbus
- InfluxDB
- typescript
- data platform
- 개발브로그
- 프로그래머스
- queue
- set활용
- python
- DP
Archives
- Today
- Total
DM Log
[완전탐색] 카펫 - Python / JavaScript 본문
문제 링크 - https://school.programmers.co.kr/learn/courses/30/lessons/42842
프로그래머스
SW개발자를 위한 평가, 교육, 채용까지 Total Solution을 제공하는 개발자 성장을 위한 베이스캠프
programmers.co.kr
[문제 간단 요약]
1. 직사각형 모양의 카펫에 주위를 brown 색으로 이루어지고 내부가 yellow 색으로 이루어진 카페트의 가로와 세로를 구하는 문제
[문제 해결 방안]
1. yellow로 이루어진 내부의 가로와 세로의 길이가 가능한 경우를 구하기
2. 구해진 가로와 세로의 합의 2배에 더하기 모서리(4개)를 더하면 brown 색의 갯수
[문제 해결 코드 - python]
def solution(brown, yellow):
answer = []
for i in range(1, yellow // 2+1):
if yellow % i == 0:
rk = yellow // i
if (i+rk) *2 +4 == brown:
break
if yellow == 1:
return [3,3]
answer.append(max(i,rk)+2)
answer.append(min(i,rk)+2)
return answer
[문제 해결 코드 - javascript]
function solution(brown, yellow) {
let answer = []
let tp
let rk
for (let i = 1; i < Math.floor(yellow / 2) + 1; i++) {
if (yellow % i === 0) {
rk = Math.floor(yellow / i)
if ((i+rk) * 2 + 4 === brown) {
tp = i
break
}
}
}
if (yellow === 1) {
return [3,3]
}
answer.push(rk + 2)
answer.push(tp + 2)
return answer;
}
'알고리즘 > 프로그래머스' 카테고리의 다른 글
[Summer/Winter Coding(~2018)] 점프와 순간 이동 - Python / JavaScript (1) | 2025.02.23 |
---|---|
[탐욕법(Greedy)] 구명보트 - Python / JavaScript (1) | 2025.02.22 |
[2017 팁스타운] 짝지어 제거하기 - Python / JavaScript (0) | 2025.02.17 |
[연습문제] 피보나치 수 - Python / JavaScript (0) | 2025.02.16 |
[연습문제] 숫자의 표 - Python / JavaScript (2) | 2025.02.09 |