[boj] (s5) 1789 수들의 합 (미완)
왜 채점이 안되지..
✅ 그리디
문제
풀이
서로 다른 N개의 수로 S를 만드는 방법 중 N이 최대가 되는 방법은,
S가 11이라고 하면,
1 + 2 + 3 + 4 =10이고, 1 + 2 + 3 + 4 + 5 = 는 15이기 때문에,
1 + 2 + 3 + 5 =11로 즉 4이다.
N이 최대여야 하기 때문에, 낮은 수부터 더해가며, 더한 값들이 S를 넘기기 직전에, 마지막으로 더하는 수를 조정하면 S를 만들 수 있다.
int로 계속 사용해서 오답이라구 나왔었는데 long long type으로 변경해주니 바로 해결할 수 있었다.
혹시 정답이 맞는데 틀리다고 계속 나온다면 type을 의심해보자.
코드
#include <iostream>
#include <algorithm>
#include <string>
using namespace std;
int main()
{
int n;
cin >> n;
int ans = 0;
long long sum = 0;
for (long long i = 1; sum < n; i++)
{
if (sum + i <= n)
{
sum += i;
ans++;
}
if (sum + i > n)
{
cout << ans << '\n';
break;
}
}
}
Author And Source
이 문제에 관하여([boj] (s5) 1789 수들의 합 (미완)), 우리는 이곳에서 더 많은 자료를 발견하고 링크를 클릭하여 보았다 https://velog.io/@peanut_/boj-s5-1789-수들의-합저자 귀속: 원작자 정보가 원작자 URL에 포함되어 있으며 저작권은 원작자 소유입니다.
우수한 개발자 콘텐츠 발견에 전념 (Collection and Share based on the CC Protocol.)