모바일 오유 바로가기
http://m.todayhumor.co.kr
분류 게시판
베스트
  • 베스트오브베스트
  • 베스트
  • 오늘의베스트
  • 유머
  • 유머자료
  • 유머글
  • 이야기
  • 자유
  • 고민
  • 연애
  • 결혼생활
  • 좋은글
  • 자랑
  • 공포
  • 멘붕
  • 사이다
  • 군대
  • 밀리터리
  • 미스터리
  • 술한잔
  • 오늘있잖아요
  • 투표인증
  • 새해
  • 이슈
  • 시사
  • 시사아카이브
  • 사회면
  • 사건사고
  • 생활
  • 패션
  • 패션착샷
  • 아동패션착샷
  • 뷰티
  • 인테리어
  • DIY
  • 요리
  • 커피&차
  • 육아
  • 법률
  • 동물
  • 지식
  • 취업정보
  • 식물
  • 다이어트
  • 의료
  • 영어
  • 맛집
  • 추천사이트
  • 해외직구
  • 취미
  • 사진
  • 사진강좌
  • 카메라
  • 만화
  • 애니메이션
  • 포니
  • 자전거
  • 자동차
  • 여행
  • 바이크
  • 민물낚시
  • 바다낚시
  • 장난감
  • 그림판
  • 학술
  • 경제
  • 역사
  • 예술
  • 과학
  • 철학
  • 심리학
  • 방송연예
  • 연예
  • 음악
  • 음악찾기
  • 악기
  • 음향기기
  • 영화
  • 다큐멘터리
  • 국내드라마
  • 해외드라마
  • 예능
  • 팟케스트
  • 방송프로그램
  • 무한도전
  • 더지니어스
  • 개그콘서트
  • 런닝맨
  • 나가수
  • 디지털
  • 컴퓨터
  • 프로그래머
  • IT
  • 안티바이러스
  • 애플
  • 안드로이드
  • 스마트폰
  • 윈도우폰
  • 심비안
  • 스포츠
  • 스포츠
  • 축구
  • 야구
  • 농구
  • 바둑
  • 야구팀
  • 삼성
  • 두산
  • NC
  • 넥센
  • 한화
  • SK
  • 기아
  • 롯데
  • LG
  • KT
  • 메이저리그
  • 일본프로야구리그
  • 게임1
  • 플래시게임
  • 게임토론방
  • 엑스박스
  • 플레이스테이션
  • 닌텐도
  • 모바일게임
  • 게임2
  • 던전앤파이터
  • 마비노기
  • 마비노기영웅전
  • 하스스톤
  • 히어로즈오브더스톰
  • gta5
  • 디아블로
  • 디아블로2
  • 피파온라인2
  • 피파온라인3
  • 워크래프트
  • 월드오브워크래프트
  • 밀리언아서
  • 월드오브탱크
  • 블레이드앤소울
  • 검은사막
  • 스타크래프트
  • 스타크래프트2
  • 베틀필드3
  • 마인크래프트
  • 데이즈
  • 문명
  • 서든어택
  • 테라
  • 아이온
  • 심시티5
  • 프리스타일풋볼
  • 스페셜포스
  • 사이퍼즈
  • 도타2
  • 메이플스토리1
  • 메이플스토리2
  • 오버워치
  • 오버워치그룹모집
  • 포켓몬고
  • 파이널판타지14
  • 배틀그라운드
  • 기타
  • 종교
  • 단어장
  • 자료창고
  • 운영
  • 공지사항
  • 오유운영
  • 게시판신청
  • 보류
  • 임시게시판
  • 메르스
  • 세월호
  • 원전사고
  • 2016리오올림픽
  • 2018평창올림픽
  • 코로나19
  • 2020도쿄올림픽
  • 게시판찾기
  • 오유인페이지
    개인차단 상태
    황금비님의
    개인페이지입니다
    가입 : 13-10-13
    방문 : 2713회
    닉네임변경 이력
    회원차단
    회원차단해제
    게시물ID : programmer_915
    작성자 : 황금비
    추천 : 0
    조회수 : 1510
    IP : 121.143.***.81
    댓글 : 0개
    등록시간 : 2014/01/30 13:17:33
    http://todayhumor.com/?programmer_915 모바일
    문자열 패턴 찾기-연습용
    <div><br /></div> <div>예전에 이스트소프트 이력서 넣고 실기 시험 문제들을 미리 풀어 볼까 해서 만든 예제 입니다.</div> <div>서류는 처음부터 통과 못했고 ㅜㅜ</div> <div><br /></div> <div>실기 문제는 문자열 패턴 최대 갯수 찾기였던 것 같습니다.</div> <div>회사에서 프로그램 만드는데 4시간 준다고 하던데 막상 그냥 해보니 능력이 모자라 4시간 더 걸렸습니다.</div> <div>다른 문제도 풀어볼려구 했는데 떨어졌다고 해서...</div> <div>회사가 알긴 아나 봅니다. ㅋㅋ</div> <div><br /></div> <div>연휴라 노트북 정리하다가 지우기 아쉬워서  어디 저장해 놓을 데 없어서 그냥 여기에 올려봅니다.</div> <div><br /></div> <div><br /></div> <div> <div> <div><br /></div> <div>#pragma warning(disable: 4996)</div> <div><br /></div> <div>#include <stdio.h></div> <div>#include <stdlib.h></div> <div>#include <string.h></div> <div><br /></div> <div>int FindMaxPattern(int* dstPos, int* dstLen, const char* sSrc, int lenSrc)</div> <div>{</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>//char<span class="Apple-tab-span" style="white-space: pre"> </span>sSrc[]="abcbabdbe";</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>int<span class="Apple-tab-span" style="white-space: pre"> </span>retMax = 0;<span class="Apple-tab-span" style="white-space: pre"> </span>// 출력용 최대 패턴 길이</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>int<span class="Apple-tab-span" style="white-space: pre"> </span>retCnt = 0;<span class="Apple-tab-span" style="white-space: pre"> </span>// 출력용 최대 패턴 숫자</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>int<span class="Apple-tab-span" style="white-space: pre"> </span>retLen = 0;<span class="Apple-tab-span" style="white-space: pre"> </span>// 출력용 최종 패턴 키 길이</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>char*<span class="Apple-tab-span" style="white-space: pre"> </span>retDst = NULL;<span class="Apple-tab-span" style="white-space: pre"> </span><span class="Apple-tab-span" style="font-size: 9pt; line-height: 1.5; white-space: pre"> </span><span style="font-size: 9pt; line-height: 1.5">// 출력용 최종 패턴 시작 위치</span></div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>int<span class="Apple-tab-span" style="white-space: pre"> </span>ptnCnt = 0;<span class="Apple-tab-span" style="white-space: pre"> </span>// 임시 패턴 숫자</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>int<span class="Apple-tab-span" style="white-space: pre"> </span>ptnMax = 0;<span class="Apple-tab-span" style="white-space: pre"> </span>// 임시 패턴 최대 길이</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>char*<span class="Apple-tab-span" style="white-space: pre"> </span>ptnKey = NULL;<span class="Apple-tab-span" style="white-space: pre"> </span><span class="Apple-tab-span" style="font-size: 9pt; line-height: 1.5; white-space: pre"> </span><span class="Apple-tab-span" style="font-size: 9pt; line-height: 1.5; white-space: pre"> </span><span style="font-size: 9pt; line-height: 1.5">// 패턴 키</span></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>char*<span class="Apple-tab-span" style="white-space: pre"> </span>ptnBgn = NULL;<span class="Apple-tab-span" style="white-space: pre"> </span><span class="Apple-tab-span" style="font-size: 9pt; line-height: 1.5; white-space: pre"> </span><span class="Apple-tab-span" style="font-size: 9pt; line-height: 1.5; white-space: pre"> </span><span style="font-size: 9pt; line-height: 1.5">// 패턴 시작 위치</span></div> <div><br /></div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>int<span class="Apple-tab-span" style="white-space: pre"> </span>n=0, k=0, i=0;</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>int<span class="Apple-tab-span" style="white-space: pre"> </span>end = 0;</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>int<span class="Apple-tab-span" style="white-space: pre"> </span>lenKey = 0;<span class="Apple-tab-span" style="white-space: pre"> </span>// 패턴 키 길이</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>char<span class="Apple-tab-span" style="white-space: pre"> </span>sAsc[128]= {0};<span class="Apple-tab-span" style="white-space: pre"> </span><span class="Apple-tab-span" style="font-size: 9pt; line-height: 1.5; white-space: pre"> </span><span style="font-size: 9pt; line-height: 1.5">// 문자 하나 체크용.</span></div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>*dstPos = -1;</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>*dstLen = 0;</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>if(NULL == sSrc || 1>=lenSrc)</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>goto END;</div> <div><br /></div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>for(n=0; n<lenSrc/2; ++n)<span class="Apple-tab-span" style="white-space: pre"> </span><span class="Apple-tab-span" style="font-size: 9pt; line-height: 1.5; white-space: pre"> </span><span class="Apple-tab-span" style="font-size: 9pt; line-height: 1.5; white-space: pre"> </span><span style="font-size: 9pt; line-height: 1.5">// 입력 문자열 길이의 절반만 수행</span></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>{</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>++lenKey;</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>end = lenSrc - lenKey;<span class="Apple-tab-span" style="white-space: pre"> </span>// 목적지 계산</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>for(k=0; k<end; ++k)</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>{</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>ptnBgn = (char*)(sSrc+k);<span class="Apple-tab-span" style="white-space: pre"> </span><span class="Apple-tab-span" style="font-size: 9pt; line-height: 1.5; white-space: pre"> </span><span style="font-size: 9pt; line-height: 1.5">// Key 생성</span></div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>if( ('A' > *ptnBgn || *ptnBgn > 'Z') &&<span class="Apple-tab-span" style="white-space: pre"> </span>//[A-Za-z0-9] 가 아니면 건너뛴다.</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>('a' > *ptnBgn || *ptnBgn > 'z') &&</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>('0' > *ptnBgn || *ptnBgn > '9') &&</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>('A' > *ptnBgn || *ptnBgn > 'z')</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>)</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>continue;</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>if(1 == lenKey)</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>{</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>if( 0 != sAsc[*ptnBgn])</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>continue;</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>sAsc[*ptnBgn] = 1;</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>}</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>ptnKey = ptnBgn;<span class="Apple-tab-span" style="white-space: pre"> </span>// Key 위치 지정</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>ptnCnt = 0;<span class="Apple-tab-span" style="white-space: pre"> </span>// 패턴 숫자 초기화</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>ptnMax = 0;</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>for(i= k+lenKey; i< end+1; )<span class="Apple-tab-span" style="white-space: pre"> </span><span class="Apple-tab-span" style="font-size: 9pt; line-height: 1.5; white-space: pre"> </span><span class="Apple-tab-span" style="font-size: 9pt; line-height: 1.5; white-space: pre"> </span><span style="font-size: 9pt; line-height: 1.5">// Key 가 만들어진 위치+ 키 길이 바로 다음부터 찾기 시작</span></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>{</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>if(0 == strncmp(sSrc+i, ptnKey, lenKey) )</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>{</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>++ptnCnt;</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span> i += lenKey;<span class="Apple-tab-span" style="white-space: pre"> </span>// 키를 찾았다면 길이만큼 증가</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>}</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>else</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span> ++i;<span class="Apple-tab-span" style="white-space: pre"> </span>// 찾기 실패. 1증가</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>}</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>if(0<ptnCnt)</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>{</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>++ptnCnt;<span class="Apple-tab-span" style="white-space: pre"> </span>// 패턴은 2번 이상 나와야 하므로...</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>ptnMax = ptnCnt * lenKey;</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>}</div> <div><br /></div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>//M이 같다면 반복 횟수가 더 많은 반복 문자열을 출력한다.</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>//M이 같고 반복 횟수가 동일하다면 앞에 나온 문자열을 출력한다.</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>// 이전 보다 큰 패턴을 찾는다.</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>if(    retMax < ptnMax</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>//<span class="Apple-tab-span" style="white-space: pre"> </span>|| (retMax == ptnMax && ptnLen < lenKey)</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>)</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>{</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>retMax = ptnMax;</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>retCnt = ptnCnt;</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>retLen = lenKey;</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>retDst = ptnKey;</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>}</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>if(1 == ptnCnt)<span class="Apple-tab-span" style="white-space: pre"> </span>// 현재 처리하는 문자열에서 패턴이 없으면 다음에도 없음. loop exit</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>goto END;</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>} // for(k=0; k<end; ++k)</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>} // for(n=0; n<lenSrc/2; ++n)</div> <div><br /></div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>if(0<retMax)</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>{</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>*dstPos = retDst - sSrc;</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>*dstLen = retLen;</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>}</div> <div><br /></div> <div>END:</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>return retCnt;</div> <div>}</div> <div><br /></div> <div><span style="font-size: 9pt; line-height: 1.5">int PatternTest()</span></div> <div>{</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>char*<span class="Apple-tab-span" style="white-space: pre"> </span>sExam[] =</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>{</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>"abcde ",</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>"12aaaaaaaaaaaaaaaaaaaaaaaaaaaa",</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>"ab12ab12abab1212 ",</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>NULL,</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>};</div> <div><br /></div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>for(int n=0; NULL != sExam[n]; ++n)</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>{</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>char*<span class="Apple-tab-span" style="white-space: pre"> </span>src    = sExam[n];</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>int<span class="Apple-tab-span" style="white-space: pre"> </span>srcLen = strlen(src);</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>int<span class="Apple-tab-span" style="white-space: pre"> </span>dstPos = -1, dstLen = -1;</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>int<span class="Apple-tab-span" style="white-space: pre"> </span>r = FindMaxPattern(&dstPos, &dstLen, src, srcLen );</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>if(0<r)</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>{</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>printf("Pattern: ");</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>fwrite(src+ dstPos, sizeof(char), dstLen, stdout);</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>printf(":%d\n", r);</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>}</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>else</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>printf("Pattern: NULL\n");</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>}</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>return 0;</div> <div>}</div> <div><br /></div> <div>int PatternConsole()</div> <div>{</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>int<span class="Apple-tab-span" style="white-space: pre"> </span>lenBuf = 1024 * 1024;</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>int<span class="Apple-tab-span" style="white-space: pre"> </span>lenRead = 1;</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>char*<span class="Apple-tab-span" style="white-space: pre"> </span>sSrc = NULL;</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>sSrc = (char*)malloc(lenBuf +4);</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>memset(sSrc, 0, lenBuf +4);</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>while(1)</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>{</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>printf("패턴 찾기: 종료하려면 \'q\'를 입력하세요.\n");</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>memset(sSrc, 0, lenRead);</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>fgets(sSrc, lenBuf, stdin);</div> <div><span class="Apple-tab-span" style="font-size: 9pt; line-height: 1.5; white-space: pre"> </span><span style="font-size: 9pt; line-height: 1.5">lenRead = strlen(sSrc);</span></div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>if(2 >= lenRead)</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>{</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>if('q' == *sSrc)<span class="Apple-tab-span" style="white-space: pre"> </span><span class="Apple-tab-span" style="font-size: 9pt; line-height: 1.5; white-space: pre"> </span><span style="font-size: 9pt; line-height: 1.5">// 프로그램 종료</span></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>break;</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>else<span class="Apple-tab-span" style="white-space: pre"> </span>// 길이가 짧음</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>{</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>printf("길이가 짧아요.\n");</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>continue;</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>}</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>}</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>sSrc[lenRead] = 0;<span class="Apple-tab-span" style="white-space: pre"> </span>// 개행 문자 처리</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>--lenRead;</div> <div><br /></div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>int<span class="Apple-tab-span" style="white-space: pre"> </span>dstPos = -1, dstLen = -1;</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>int<span class="Apple-tab-span" style="white-space: pre"> </span>r = FindMaxPattern(&dstPos, &dstLen, sSrc, lenRead );</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>if(0<r)</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>{</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>printf("Pattern: ");</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>fwrite(sSrc+ dstPos, sizeof(char), dstLen, stdout);</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>printf(":%d\n", r);</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>}</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>else</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>printf("Pattern: NULL\n\n");</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>}</div> <div><br /></div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>printf("프로그램 종료\n");</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>free(sSrc);</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>return 0;</div> <div>}</div> <div><br /></div> <div><br /></div> <div>int PatternFile(int argc, char** argv)</div> <div>{</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>char*<span class="Apple-tab-span" style="white-space: pre"> </span>sFileSrc = "F:/in.txt";</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>char*<span class="Apple-tab-span" style="white-space: pre"> </span>sFileDst = "F:/out.txt";</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>char*<span class="Apple-tab-span" style="white-space: pre"> </span>sSrc = NULL;</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>FILE*<span class="Apple-tab-span" style="white-space: pre"> </span>fi = NULL;<span class="Apple-tab-span" style="white-space: pre"> </span>// source file</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>FILE*<span class="Apple-tab-span" style="white-space: pre"> </span>fo = NULL;<span class="Apple-tab-span" style="white-space: pre"> </span>// dest file</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>int<span class="Apple-tab-span" style="white-space: pre"> </span>lenBuf = 0;</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>int<span class="Apple-tab-span" style="white-space: pre"> </span>lenRead = 1;</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>if(3 > argc)</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>{</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>printf(<span class="Apple-tab-span" style="white-space: pre"> </span>"Error:인수가 적습니다. "</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>"입력 파일은 %s 출력 파일은 %s로 대처 합니다.\n"</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>, sFileSrc, sFileDst</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>);</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>fi = fopen(sFileSrc, "rt");</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>fo = fopen(sFileDst, "wt");</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>}</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>else</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>{</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>char*<span class="Apple-tab-span" style="white-space: pre"> </span>sFileSrc = argv[1];</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>char*<span class="Apple-tab-span" style="white-space: pre"> </span>sFileDst = argv[2];</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>fi = fopen(argv[1], "rt");<span class="Apple-tab-span" style="white-space: pre"> </span>// source file</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>fo = fopen(argv[2], "wt");<span class="Apple-tab-span" style="white-space: pre"> </span>// dest file</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>}</div> <div><br /></div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>if(NULL == fi)</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>{</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>printf("입력 파일을 열 수 없습니다.\n");</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>return 0;</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>}</div> <div><br /></div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>if(NULL == fo)</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>{</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>printf("출력 파일을 열 수 없습니다.\n");</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>return 0;</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>}</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>fseek(fi, 0, SEEK_END);</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>lenBuf = ftell(fi);</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>fseek(fi, 0, SEEK_SET);</div> <div><br /></div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>sSrc = (char*)malloc( 4* ( (lenBuf +7)/4 ) );</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>memset(sSrc, 0, 4* ( (lenBuf +7)/4 ) );</div> <div><br /></div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>lenRead = fread(sSrc, sizeof(char), lenBuf, fi);</div> <div><br /></div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>int<span class="Apple-tab-span" style="white-space: pre"> </span>dstPos = -1, dstLen = -1;</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>int<span class="Apple-tab-span" style="white-space: pre"> </span>r = FindMaxPattern(&dstPos, &dstLen, sSrc, lenRead );</div> <div><br /></div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>if(0<r)</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>{</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>fwrite(sSrc+ dstPos, sizeof(char), dstLen, fo);</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>fprintf(fo, ":%d\n", r);</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>fwrite(sSrc+ dstPos, sizeof(char), dstLen, stdout);</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>printf(":%d\n", r);</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>}</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>else</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>{</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>fprintf(fo, "NULL\n");</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>printf("Pattern: NULL\n\n");</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>}</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>free(sSrc);</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>fclose(fi);</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>fclose(fo);</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>return 0;</div> <div>}</div> <div><br /></div> <div>// program main</div> <div>int main(int argc, char** argv)</div> <div>{</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>PatternTest();</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>//PatternConsole();</div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>//PatternFile(argc, argv);</div> <div><br /></div> <div><span class="Apple-tab-span" style="white-space: pre"> </span>return 0;</div> <div>}</div> <div><br /></div></div> <div><br /></div></div>
    황금비의 꼬릿말입니다
    젊어 고생 늙어 고생. 안되는 사람은 그냥 편안히...

    이 게시물을 추천한 분들의 목록입니다.
    푸르딩딩:추천수 3이상 댓글은 배경색이 바뀝니다.
    (단,비공감수가 추천수의 1/3 초과시 해당없음)

    죄송합니다. 댓글 작성은 회원만 가능합니다.

    번호 제 목 이름 날짜 조회 추천
    42
    매달 추천 리스트 만들면 좋을 것 같습니다. [5] 황금비 14/08/26 11:14 35 0
    41
    저장용 사무용 견적 [3] 황금비 14/08/24 11:00 70 1/5
    40
    ssd 추천 [1] 황금비 14/08/16 13:07 28 0
    39
    프로그래밍 팁 - vc폴더의 소스를 분석해보자. 황금비 14/08/11 19:37 31 1
    38
    사무용 PC 견적 팁. 추천 제품 시세 [8] 황금비 14/08/06 14:47 72 6
    37
    사무용 견적 셀러론+ 4G, i3 + 8G 황금비 14/08/06 09:42 49 0
    36
    사무용 콩 견적 황금비 14/08/06 07:33 63 0
    35
    초등학교 프로그래밍 교육 황금비 14/07/30 00:37 27 1
    34
    안드로이드 개발 어떴습니까? 멘붕이네요. [1] 황금비 14/07/08 19:51 35 0
    33
    아래 학벌에 대한 고민 글 보고 황금비 14/05/17 12:12 40 3
    32
    크리스마스 트리 그까이꺼 대충 [2] 황금비 14/04/29 16:10 52 0
    31
    hack 황금비 14/03/26 09:24 25 0
    30
    견적업체 질문입니다. [4] 황금비 14/02/18 20:53 31 0
    29
    포터블 c 황금비 14/02/09 10:49 30 0
    28
    마영전 가능한가요? [4] 황금비 14/02/08 09:46 68 0
    27
    포인터 쉽게 이해하기. [4] 황금비 14/02/02 23:15 29 2
    문자열 패턴 찾기-연습용 황금비 14/01/30 13:17 23 0
    25
    21일 완성 시리즈 로 성공해 보신분 있나요? 황금비 14/01/17 00:16 27 0
    24
    PC용 500GB 외장하드 ㅋ [4] 황금비 14/01/10 09:27 130 0
    23
    90만원대 견적 [3] 황금비 14/01/09 15:50 100 0
    22
    나는 어쩌다 암드 빠돌이에서 엔당 빠돌이가 되었나? [4] 황금비 14/01/08 23:40 64 1
    21
    국민 PC CPU, 보드, 메모리, 하드 [5] 황금비 14/01/08 23:17 79 0
    20
    스마트폰 게임개발용. 황금비 14/01/08 00:12 43 0
    19
    사무용 컴퓨터의 ssd 시대 [11] 황금비 14/01/07 09:57 158 1
    18
    냥이 키우기 - c 프로그래밍 [1] 황금비 14/01/02 11:07 63 1
    17
    22 - 사무용/업무용 [8] 황금비 14/01/02 09:24 70 0
    16
    사무용 25만원 발암견적[3] [2] 황금비 14/01/02 01:16 55 0
    15
    22 만원 발암견적[2] [7] 황금비 14/01/02 00:52 91 0
    14
    게임 개발용 70 만원대 컴퓨터 입니다. [3] 황금비 13/12/27 13:53 103 0
    13
    전원 공급 와트 계산 사이트입니다. [8] 황금비 13/12/22 21:29 43 0
    [1] [2] [3] [4]
    단축키 운영진에게 바란다(삭제요청/제안) 운영게 게시판신청 자료창고 보류 개인정보취급방침 청소년보호정책 모바일홈