반응형
안녕하세요? 수구리입니다.
이번 포스팅은 프로그래머스 Level 1 문제를 풀어보려고 합니다!
이제는 문제의 제목만 보아도 어떤 문제인지 대충 감이 오시죠?!
바로 문제를 보도록 하겠습니다..!
[ 문제 ] 프로그래머스: 두 정수 사이의 합
https://programmers.co.kr/learn/courses/30/lessons/12912
[ 나의 풀이 ]
#include <string>
#include <vector>
using namespace std;
long long solution(int a, int b) {
long long answer = 0;
if ( a == b ){
return a;
} else if (a < b) {
for (int i = a; i <= b; i++)
answer += i;
} else {
for (int i = b; i <= a; i++)
answer += i;
}
return answer;
}
[ 다른 풀이 ]
#include <string>
#include <vector>
using namespace std;
long long solution(int a, int b) {
return (long long)(a + b) * (abs(a - b) + 1) / 2;
}
위의 풀이는 시그마 공식을 이용한 해답이군요..! 정말 신기합니당..
[ 설명 ]
1. 문제에서 만약 인자로 넘어온 값이 같으면 둘 중 하나를 리턴하면 되므로 저는 a를 리턴하였습니다.
2. 만약 a가 b보다 작다면, a부터 반복문을 시작하며, b까지의 모든 합을 answer 변수에 저장합니다.
3. 2의 경우가 아니라면, b부터 a까지 반복문을 순회하면서 모든 합을 answer 변수에 저장합니다.
4. 마지막으로 answer 값을 반환합니다.
이상으로 두 정수 사이의 합이었습니다.
감사합니다!
반응형
'✏️ PS > Programmers' 카테고리의 다른 글
[ C++ ] 프로그래머스: 약수의 합 (0) | 2021.12.30 |
---|---|
[ C++ ] 프로그래머스: 서울에서 김서방 찾기 (0) | 2021.12.21 |
[ python ] 프로그래머스: 수박수박수박수박수? (0) | 2021.12.14 |
[ C++ ] 프로그래머스: 신규 아이디 추천 (0) | 2021.12.13 |
[ C++ ] 프로그래머스: 로또의 최고 순위와 최저 순위 (2) | 2021.12.10 |