logo

English

이곳의 프로그래밍관련 정보와 소스는 마음대로 활용하셔도 좋습니다. 다만 쓰시기 전에 통보 정도는 해주시는 것이 예의 일것 같습니다. 질문이나 오류 수정은 siseong@gmail.com 으로 주세요. 감사합니다.

brute-force 알고리즘을 이용한 패턴 위치 찾기

by digipine posted Oct 29, 2017
?

Shortcut

PrevPrev Article

NextNext Article

Larger Font Smaller Font Up Down Go comment Print
?

Shortcut

PrevPrev Article

NextNext Article

Larger Font Smaller Font Up Down Go comment Print

// brute-force 알고리즘을 이용한 패턴 위치 찾기

#include <stdio.h>
#include <string.h>

int brutesearch();

main()
{
         char Text[] = "aababba";   
         char Pattern[] = "abb";
         
         int indexPattern = brute(Pattern, Text);

         if(indexPattern == -1)
                  printf("[Failure] Can't Find Pattern <%s>", Pattern);
                  else 
                                printf("[Success] Index of Pattern <%s> at <%s> => %d \n", Pattern, Text, indexPattern+1);
}

int brute(char *p, char *a) //brute-force 탐색 알고리즘
{
         int i, j, M=strlen(p), N=strlen(a);
         for (i=0, j=0; j<M && i<N; i++, j++){
                  while(a[i] != p[j])
                  {
                                i -= j-1;
                                j=0;
                  }
                  if (j == M) return(i-M);
                  else return (i);
         }
}

 

//출력은 [Success] Index of Pattern <abb> at <aababba> => 4
//알고리즘에 대한 설명은 교재를 참조하세요!!
//교재는 정익사 출판사의 C언어로 설명한 알고리즘 입니다.

 

List of Articles
No. Subject Author Date Views
3 STL MAP 예제로 공부하기 digipine 2017.10.29 5206
2 C++에서 extern의 역할, 기능 digipine 2017.10.29 2674
1 [C/C++] 현재시간 구하기 digipine 2017.10.28 2212
Board Pagination Prev 1 2 Next
/ 2