
문제 설명
두 정수 a, b가 주어졌을 때 a와 b 사이에 속한 모든 정수의 합을 리턴하는 함수, solution을 완성하세요.
예를 들어 a = 3, b = 5인 경우, 3 + 4 + 5 = 12이므로 12를 리턴합니다.
제한 조건
- a와 b가 같은 경우는 둘 중 아무 수나 리턴하세요.
- a와 b는 -10,000,000 이상 10,000,000 이하인 정수입니다.
- a와 b의 대소관계는 정해져있지 않습니다.
입출력 예
a | b | return |
3 | 5 | 12 |
3 | 3 | 3 |
5 | 3 | 12 |
나의 풀이
import java.lang.Math;
class Solution {
public long solution(int a, int b) {
long answer = 0;
if(a == b){
return a;
}else{
int max = Math.max(a, b);
int min = Math.min(a, b);
for(int i = min; i <= max; i++)
answer += i;
return answer;
}
}
}
다른 풀이1
class Solution {
public long solution(int a, int b) {
long answer = 0;
if (a < b) {
for (int i = a; i <= b; i++) {
answer += i;
}
} else {
for (int i = b; i <= a; i++) {
answer += i;
}
}
return answer;
}
}
다른 풀이2
// 삼항연산자 사용
class Solution {
public long solution(int a, int b) {
long answer = 0;
for (int i = ((a < b) ? a : b); i <= ((a < b) ? b : a); i++)
answer += i;
return answer;
}
}
다른 풀이3
// 등차수열의 합 공식
class Solution {
public long solution(int a, int b) {
return sumAtoB(Math.min(a, b), Math.max(b, a));
}
private long sumAtoB(long a, long b) {
return (b - a + 1) * (a + b) / 2;
}
}
'👨💻 Coding Test > 구현' 카테고리의 다른 글
[Programmers/Java/Lv.1/문자열 유형] 10.문자열 내 p와 y의 개수 (0) | 2025.04.05 |
---|---|
[Programmers/Java/Lv.1/문자열 유형] 7.문자열 내 마음대로 정렬하기 (0) | 2025.04.01 |
[Programmers/Java/Lv.1/수학 유형] 5.나누어 떨어지는 숫자 배열 (0) | 2025.03.27 |
[Programmers/Java/Lv.1/스택] 4.같은 숫자는 싫어 (0) | 2025.03.27 |
[Programmers/Java/Lv.1/문자열 유형] 3.가운데 글자 가져오기 (0) | 2025.03.25 |

문제 설명
두 정수 a, b가 주어졌을 때 a와 b 사이에 속한 모든 정수의 합을 리턴하는 함수, solution을 완성하세요.
예를 들어 a = 3, b = 5인 경우, 3 + 4 + 5 = 12이므로 12를 리턴합니다.
제한 조건
- a와 b가 같은 경우는 둘 중 아무 수나 리턴하세요.
- a와 b는 -10,000,000 이상 10,000,000 이하인 정수입니다.
- a와 b의 대소관계는 정해져있지 않습니다.
입출력 예
a | b | return |
3 | 5 | 12 |
3 | 3 | 3 |
5 | 3 | 12 |
나의 풀이
import java.lang.Math;
class Solution {
public long solution(int a, int b) {
long answer = 0;
if(a == b){
return a;
}else{
int max = Math.max(a, b);
int min = Math.min(a, b);
for(int i = min; i <= max; i++)
answer += i;
return answer;
}
}
}
다른 풀이1
class Solution {
public long solution(int a, int b) {
long answer = 0;
if (a < b) {
for (int i = a; i <= b; i++) {
answer += i;
}
} else {
for (int i = b; i <= a; i++) {
answer += i;
}
}
return answer;
}
}
다른 풀이2
// 삼항연산자 사용
class Solution {
public long solution(int a, int b) {
long answer = 0;
for (int i = ((a < b) ? a : b); i <= ((a < b) ? b : a); i++)
answer += i;
return answer;
}
}
다른 풀이3
// 등차수열의 합 공식
class Solution {
public long solution(int a, int b) {
return sumAtoB(Math.min(a, b), Math.max(b, a));
}
private long sumAtoB(long a, long b) {
return (b - a + 1) * (a + b) / 2;
}
}
'👨💻 Coding Test > 구현' 카테고리의 다른 글
[Programmers/Java/Lv.1/문자열 유형] 10.문자열 내 p와 y의 개수 (0) | 2025.04.05 |
---|---|
[Programmers/Java/Lv.1/문자열 유형] 7.문자열 내 마음대로 정렬하기 (0) | 2025.04.01 |
[Programmers/Java/Lv.1/수학 유형] 5.나누어 떨어지는 숫자 배열 (0) | 2025.03.27 |
[Programmers/Java/Lv.1/스택] 4.같은 숫자는 싫어 (0) | 2025.03.27 |
[Programmers/Java/Lv.1/문자열 유형] 3.가운데 글자 가져오기 (0) | 2025.03.25 |