๋ฐ์ํ
๐ก๋ฌธ์ ์ค๋ช
๋ ์ ์ left์ right๊ฐ ๋งค๊ฐ๋ณ์๋ก ์ฃผ์ด์ง๋๋ค.
left๋ถํฐ right๊น์ง์ ๋ชจ๋ ์๋ค ์ค์์, ์ฝ์์ ๊ฐ์๊ฐ ์ง์์ธ ์๋ ๋ํ๊ณ ,
์ฝ์์ ๊ฐ์๊ฐ ํ์์ธ ์๋ ๋บ ์๋ฅผ return ํ๋๋ก solution ํจ์๋ฅผ ์์ฑํด์ฃผ์ธ์.
์ ์ถ๋ ฅ ์
left | right | result |
13 | 17 | 43 |
24 | 27 | 52 |
์ ์ถ๋ ฅ ์ ์ค๋ช #1
- ๋ค์ ํ๋ 13 ๋ถํฐ 17๊น์ง ์๋ค์ ์ฝ์๋ฅผ ๋ชจ๋ ๋ํ๋ธ ๊ฒ์ ๋๋ค.
์ | ์ฝ์ | ์ฝ์์ ๊ฐ์ |
13 | 1, 13 | 2 |
14 | 1, 2, 7, 14 | 4 |
15 | 1, 3, 5, 15 | 4 |
16 | 1, 2, 4, 8, 16 | 5 |
17 | 1, 17 | 2 |
- ๋ฐ๋ผ์, 13 + 14 + 15 - 16 + 17 = 43 ์ return ํด์ผ ํฉ๋๋ค.
์ ์ถ๋ ฅ ์ ์ค๋ช #2
- ๋ค์ ํ๋ 24๋ถํฐ 27๊น์ง์ ์๋ค์ ์ฝ์๋ฅผ ๋ชจ๋ ๋ํ๋ธ ๊ฒ์ ๋๋ค.
์ | ์ฝ์ | ์ฝ์์ ๊ฐ์ |
24 | 1, 2, 3, 4, 6, 8, 12, 24 | 8 |
25 | 1, 5, 25 | 3 |
26 | 1, 2, 13, 26 | 4 |
27 | 1, 3, 9, 27 | 4 |
- ๋ฐ๋ผ์, 24 - 25 + 26 + 27 = 52๋ฅผ return ํด์ผ ํฉ๋๋ค.
answer case 1: 2์ค for ๋ฌธ์ผ๋ก ์ผ์ชฝ์ ์ซ์๋ฅผ ๋์ ์์ผ์ ์ง์๋ +i ๋ํด์ฃผ๊ณ ํ์๋ +(i * -1) ํด์ค์ผ๋ก์จ ๋นผ์ค๋ค.
class Solution {
public int solution(int left, int right) {
int answer = 0;
int cnt = 0;
for(int i = left; i <= right; i++){
cnt = 0;
for(int j = 1; j<= i; j++){
if( i % j == 0) cnt++;
}
answer += (cnt%2 == 0) ? i : (i*-1);
/* ์ง์๋ +i ๋ํด์ฃผ๊ณ ํ์๋ +(i * -1) ํด์ค์ผ๋ก์จ ๋นผ์ค๋ค. */
}
return answer;
}
}
answer case 2: Math.sqrt() = ์ ๊ณฑ๊ทผ์ ๊ตฌํ๋ ํจ์
class Solution {
public int solution(int left, int right) {
int answer = 0;
for (int i=left;i<=right;i++) {
/* ์ ๊ณฑ์์ธ ๊ฒฝ์ฐ ์ฝ์์ ๊ฐ์๊ฐ ํ์ */
if (i % Math.sqrt(i) == 0) {
answer -= i;
}
/* ์ ๊ณฑ์๊ฐ ์๋ ๊ฒฝ์ฐ ์ฝ์์ ๊ฐ์๊ฐ ์ง์ */
else {
answer += i;
}
}
return answer;
}
}
300x250
'Algorithm > ํ๋ก๊ทธ๋๋จธ์ค' ์นดํ ๊ณ ๋ฆฌ์ ๋ค๋ฅธ ๊ธ
2022 KAKAO ๋ธ๋ผ์ธ๋ ์ฝ๋ฉํ ์คํธ - ์ ๊ณ ๊ฒฐ๊ณผ ๋ฐ๊ธฐ (0) | 2022.04.01 |
---|---|
[Java] ํ๋ก๊ทธ๋๋จธ์ค - x๋งํผ ๊ฐ๊ฒฉ์ด ์๋ n๊ฐ์ ์ซ์ (0) | 2022.03.20 |
[Java] ํ๋ก๊ทธ๋๋จธ์ค - 3์ง๋ฒ ๋ค์ง๊ธฐ (์ ๋ต / ์ค๋ช ) (0) | 2022.03.11 |
[JAVA] 1 ๋ถํฐ 100๊น์ง ์ซ์๋ฅผ ํฉํ๋ ์๊ณ ๋ฆฌ์ฆ (0) | 2022.02.26 |
[JAVA] ํ๋ก๊ทธ๋๋จธ์ค - ์์ ์๋ผํ ์คํ ๋ค์ค์ ์ฒด (0) | 2022.02.23 |