문제 링크 https://programmers.co.kr/learn/courses/30/lessons/12912
문제
두 정수 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가 크게 되면 swap함수로 두 값을 바꿔주면 된다.
풀이1
#include <string>
#include <vector>
using namespace std;
long long solution(int a, int b) {
long long answer = 0;
if(a > b) swap(a, b);
for(int i = a; i <= b; i++){
answer += i;
}
return answer;
}
풀이2
#include <string>
#include <vector>
using namespace std;
long long solution(int a, int b) {
long long answer = 0;
// swap 함수 구현
if(a > b) {
int temp = a;
a = b;
b = temp;
}
for(int i = a; i <= b; i++){
answer += i;
}
return answer;
}
댓글남기기