cyphen156
백준-시간복잡도 24313 알고리즘 수업 - 점근적 표기 1 본문
빅 - O표기법에 대해
O(g(n)) = {f(n) | 모든 n ≥ n0에 대하여 f(n) ≤ c × g(n)인 양의 상수 c와 n0가 존재한다}가
f(n) = an + b :: O(N)정의를 만족하는지 알아보자
f(n), c, n0가 O(n) 정의를 만족하면 1, 아니면 0을 출력한다.
제약사항
- 0 <= | a |, | b | <= 100
- 0 < C <= 100
- 0 < n <= 100
주의 사항
없다.
CPP풀이
알고리즘 수업 - 점근적 표기1_24313.cpp
/**
* 백준 알고리즘 수업 - 점근적 표기1_24313
* 빅 - O표기법에 대해
* O(g(n)) = {f(n) | 모든 n ≥ n0에 대하여 f(n) ≤ c × g(n)인 양의 상수 c와 n0가 존재한다}
* f(n) = an + b :: O(N)정의를 만족하는지 알아보자
* f(n), c, n0가 O(n) 정의를 만족하면 1, 아니면 0을 출력한다.
*
* 제한사항
*****************************************
* 0 <= | a |, | b | <= 100 *
* 0 < C <= 100 *
* 0 < n <= 100 *
*****************************************
*
*
*
* 주의
* 없다.
*
* 풀이시간 0분
*/
#include <iostream>
using namespace std;
bool checkBigO(int a, int b, int c, int n0) {
for (int n = n0; n <= 10000; n++) { // n0 이상 모든 n에 대해 검사
if (a * n + b > c * n) {
return false;
}
}
return true;
}
int main(void) {
int a, b, c, n0;
cin >> a >> b;
cin >> c;
cin >> n0;
cout << (checkBigO(a, b, c, n0) ? 1 : 0) << endl;
return 0;
}
모든 예제 코드의 소스파일은 제 개인 깃허브 레포지토리 에 있습니다.
Workspace/알고리듬 풀이 at main · cyphen156/Workspace
Studying . Contribute to cyphen156/Workspace development by creating an account on GitHub.
github.com
'컴퓨터공학 > 알고리듬 풀이' 카테고리의 다른 글
백준-브루트 포스 2231 분해합 (0) | 2025.04.01 |
---|---|
백준-브루트 포스 2798 블랙잭 (0) | 2025.03.11 |
백준-시간복잡도 24266 알고리즘 수업 - 알고리즘의 수행 시간 5 (0) | 2025.03.07 |
백준-시간복잡도 24265 알고리즘 수업 - 알고리즘의 수행 시간 4 (0) | 2025.03.07 |
백준-시간복잡도 24264 알고리즘 수업 - 알고리즘의 수행 시간 3 (0) | 2025.03.06 |