문제 링크 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;
}

댓글남기기