반응형

분류 전체보기 685

(C언어) strstr: 문자열에서 특정 문자열을 검색한다

#include char *strstr(const char *s1, const char *s2); 주어진 문자열 s1에서 s2와 일치하는 문자를 검색합니다. 문자열을 찾았으면 찾은 문자열의 포인터를 반환하고, 찾지 못했으면 NULL을 반환합니다. 예제 #include #include int main() { char* s1 = "It is always interesting to keep an eye on promising new programming languages."; char* s2 = "new"; char* ptr; ptr = strstr(s1, s2); if (ptr != NULL) printf("%s\n", ptr); return 0; }

(C언어) 입력 버퍼 비우기: rewind fflush

C언어 프로그램에서 %d, %c 등을 계속 반복해서 입력 받을 때 엔터 문자 때문에 입력을 받지 않고 건너 띄는 경우가 있습니다. %c가 이전에 입력한 엔터 문자를 받아서 넘겨 버리기 때문입니다. 몇 가지 방법으로 해결할 수 있습니다. 1. rewind rewind(stdin); // 입력 버퍼를 비운다. %c 를 이용해서 입력 받은 문장 바로 앞에 추가합니다. rewind(stdin); scanf("%c", &c; 2. fflush fflush(stdin); // 입력 버퍼를 비운다. fflush() 함수는 표준이 아닙니다. 리눅스나 DevC++에서는 잘 동작하지만 Visual Studio에서는 사용할 수 없습니다. 3. while(getchar()!='/n'); // 주의: 맨 뒤에 세미콜론(;)문자..

C_C++ 2022.11.20

(C/C++) 하노이 탑 Tower of Hanoi

#C언어 #하노이타워 #하노이 #타워 #퍼즐 #hanoitower #퀴즈 #퍼즐 하노이 탑(Tower of Hanoi) 세 개의 기둥과 이 기둥에 꽂을 수 있는 여러 개의 원판이 있다. 첫번째 기둥에 쌓여 있는 원판을 세 번째 기둥으로 옮기는 것이다. 한 번에 한 개씩 옮길 수 있다. 가장 위에 있는 원판만 옮길 수 있다. 큰 원판이 작은 원판 위에 있으면 안된다. C언어 #include void hanoitower(int n, char a, char b, char c) { if (n > 0) { hanoitower(n - 1, a, c, b); printf("%d번 원반을 %c 에서 %c 로 옮김\n", n, a, b); hanoitower(n - 1, c, b, a); } } int main() { ..

카테고리 없음 2022.11.20

(C언어) strtok: 문자열 분리

#include char *strtok(char *s1, const char *s2); strcok 함수는 문자열 s1을 분리 문자열 s2를 이용해서 다음 토큰을 찾습니다. s1에서 발결된 다음 토큰의 포인터를 반환합니다. 더 이상 토큰을 찾을 수 없으면 NULL을 반환합니다. strtok 함수의 첫 번째 호출은 s1에 있는 첫 번째 토큰의 포인터를 반환하고 반환된 토큰 다음에 NULL을 써 넣습니다. 첫 번째 인수로 NULL을 사용한 strtok 함수의 두 번째 호출은 토큰 다음에 나오는 문자의 포인터를 반환합니다. 예제 #define _CRT_SECURE_NO_WARNINGS // Visual Studio #include #include int main() { char string[] = "It is..

C_C++ 2022.11.19

(C/C++) 병합정렬 Merge Sort

#병합 #정렬 #머지소트 #C언어 #배열 #Array 병합정렬(Merge Sort) 이미 정렬되어 있는 2개 이상의 부분 집합들을 크기순으로 한 개로 합치는 것을 말합니다. C언어 코드 #include #define NA 10 #define NB 5 #define NC (NA+NB) int main() { int a[NA] = { 11,22,33,44,55,66,77,88,87,88 }; int b[NB] = { 10,30,35,78,90 }; int c[NC]; int i, j, p; i = j = p = 0; while (i < NA && j < NB) { // a, b 둘 중 한 개가 먼저 끝날때까지 반복 if (a[i]

(C언어) 이진 검색(binary search)

#이진검색 #바이너리서치 #이진탐색 #검색 #탐색 #2진검색 이진 검색(binary search)은 오름 차순으로 정렬되어 있는 데이터를 2등분하여, 앞쪽에 있는지 뒤쪽에 있는지 검색해 나가는 방법입니다. 이진검색 전제조건: - 크기순으로 반드시 정렬되어 있을 것 *. 찾는 값이 47일 때 1. 데이터가 10개 일때(0~9번) C언어: 이진 검색 #define _CRT_SECURE_NO_WARNINGS // Visual Studio #include #define N 10 int main() { int a[N] = { 1, 5, 8, 15, 30, 45, 47, 55, 80, 99 }; int key, low, high, mid; int flag = 0; printf("탐색할 데이터는(1~100)? ");..

(C언어) 원주율 파이 구하기 3.1415926535897

#원주율 #3.14159 #1000자리 #파이 #원주율를 구하는 C언어 코드 #include void ladd(short*, short*, short*); void lsub(short*, short*, short*); void ldiv(short*, short, short*); void printresult(short*); #define L 1000 /* 자리수 */ #define L1 ((L/4)+1) #define L2 (L1+1) #define N (short)(L/1.39794+1) int main(void) { static short s[L2 + 2], w[L2 + 2], v[L2 + 2], q[L2 + 2]; short k; for (k = 0; k = 0; i--) { c[i] = a[i] ..

C_C++ 2022.11.17
반응형