프로그래밍 언어들 썸네일형 리스트형 C언어 레드-블랙 트리 삽입 알고리즘 (Red-Black Trees in C, insertion algorithm) C언어 레드-블랙 트리 삽입 알고리즘 (Red-Black Trees in C, insertion algorithm) - 많은 검색-트리 구조 중 하나이다. - 기본 동적 명령들이 최악의 경우에도 O(lg n) 시간이 걸리도록 보장하기 위해 안정(balanced) 되었다. - 각 노드마다 하나의 추가적인 비트를 가지고 있다. - 편리한 상태처리를 위해 NIL을 나타내는 센티널 노드가 있다. - 다음 5가지의 특성을 만족하는 이진 트리이다. (1) 각 노드는 빨강 또는 검정색이다. (2) 루트(root)는 검정색이다. (3) 모든 leaf(NULL)은 블랙이다. (4) 만약 노드가 빨강이면, 해당 노드의 자식은 모두 검정이다. (5) 각 노드에 대해, 해당 노드에서 자식 노드까지의 모든 경로들은 같은 수의 .. 더보기 C언어 전위연산 및 후위연산 C언어 전위연산 및 후위연산 1. 증감 연산자 어떤 변수가 가진 값을 1 증가시키거나 1 감소시킬 때, 간단하게 사용할 수 있는 연산자입니다. 앞서 학습한 내용에 의하면, 변수가 가진 값을 변경하려면 아래와 같이 작성해야 합니다. 예) m이 가진 값을 1 증가 시킬 경우, m = m + 1; 이고 m += 1; 이라고 쓸 수도 있습니다. 예) k가 가진 값을 5 감소 시킬 경우, k = k - 5; 이고 k -= 5; 라고 쓸 수도 있습니다. int main (void) { int m, n, k; m = 10; n = 10; k = 10; m = m + 1; // m += 1; n++; k--; } 위의 소스를 보시면, 앞서 설명한 방법대로 연산한 것과 ++ 또는 --를 이용하여 연산한 것이 있습니다. .. 더보기 C언어 문제 - 10개의 피보나치 수열 출력하기 (questions in C) C언어 문제 - (questions in C) - 10개의 피보나치 수열 (1 + 1 + 2 + 3 + 5 .. 55)을 출력하십시오. #include int main (void) { int i; int first, second; int value; first = 1; second = 1; for( i = 1 ; i 더보기 C언어 문제 - n 부터 m 까지의 합 구하기 (questions in C) C언어 문제 - (questions in C) - 두 정수 n과 m을 입력 받으십시오. - n 부터 m 까지의 합을 구하시오. #include int main (void) { int n; int m; int sum = 0; scanf("%d%d", &n, &m); for( ; n 더보기 C언어 문제 - n과 m 사이의 3의 배수이면서 짝수인 수 출력하기 (questions in C) C언어 문제 - (questions in C) - 두 정수 n과 m을 입력 받으십시오. - n 부터 m 사이에 있는 수들 중 3의 배수이면서 짝수인 수를 출력하십시오. #include int main (void) { int n; int m; scanf("%d%d", &n, &m); for( ; n 더보기 C언어 문제 - 입력받은 수 사이의 7의 배수 출력하기 (questions in C) C언어 문제 - (questions in C) - 1부터 입력받은 수 사이에 있는 수들 중에 7의 배수인 수를 출력하십시오. #include int main (void) { int n; int i; scanf("%d", &n); for( i = 1 ; i 더보기 C언어 문제 - 입력받은 수까지 출력하기 (questions in C) C언어 문제 - (questions in C) - 1부터 입력받은 수까지 출력하십시오.(for문 이용) #include int main (void) { int n; int i; scanf("%d", &n); for( i = 1 ; i 더보기 C언어 문제 - 네 정수의 최대 값 출력하기(삼항연산자) (questions in C) C언어 문제 (questions in C) - 4개의 정수를 입력받고, 삼항연산자를 이용하여 4개의 수 중 가장 큰 값을 출력하시오. #include int main (void) { int x, y, z, k; int max; scanf("%d%d%d%d", &x, &y, &z, &k); max = (x > y)? x : y; max = (max > z)? max : z; max = (max > k)? max : k; printf("%d\n", max); } 더보기 C언어 문제 - 학점을 입력받아 점수 출력하기(switch~case문) (questions in C) C언어 문제 - (questions in C) - switch~case 문을 이용하여 학점(A,B,C,F)를 입력받아 A이면 90점 이상입니다, B이면 80점 이상입니다. C이면 70점 이상입니다.를 출력하고 F이면 70점 미만입니다.를 출력하라. (단, A,B,C,F가 아닌 다른 문자를 입력할 경우 "잘못된 입력"이라고 출력할 것) #include int main (void) { char grade; scanf("%c", &grade); switch(grade) { case 'A': printf("90점 이상입니다.\n"); break; case 'B': printf("80점 이상입니다.\n"); break; case 'C': printf("70점 이상입니다.\n"); break; case 'F': p.. 더보기 C언어 문제 - 점수를 입력받아 학점 출력하기(switch~case문) (questions in C) C언어 문제 - (questions in C) - switch~case 문을 이용하여 점수(0~100)를 입력받아 90~100이면 A, 80~89면 B, 70~79면 C이고 나머지는 F를 출력하라. (단, case 문은 5개 이하만 사용할 것) #include int main (void) { int score; scanf("%d", &score); switch(score/10) { case 10: case 9: printf("A\n"); break; case 8: printf("B\n"); break; case 7: printf("C\n"); break; default: printf("F\n"); } } 더보기 이전 1 2 3 4 5 6 7 ··· 10 다음