게임 클라이언트 개발/알고리즘 문제

[프로그래머스 level 1] 두 정수 사이의 합

주운녕 2020. 8. 3. 17:50

[출처 : 프로그래머스]

문제

문제 설명

두 정수 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의 대소관계는 정해져있지 않습니다.


풀이

#include <stdio.h>
#include <stdbool.h>
#include <stdlib.h>
#define swap(x, y, temp)    (temp=x, x=y, y=temp)
long long solution(int a, int b) {
    long long answer = 0;
    int temp;
    if(a>b) swap(a, b, temp);
    for(int i=a; i<=b; i++){
        answer += i;
    }
    return answer;
}

swap 디파인을 활용해서 코드를 보다 간결하게 했다.

 


* 개인적인 학습 목적으로 작성한 글이기에 내용에 잘못된 정보가 있을 수 있습니다.

* 문제 출처 - https://programmers.co.kr/learn/courses/30/lessons/12912