모바일 오유 바로가기
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
    조회수 : 1512
    IP : 121.143.***.81
    댓글 : 0개
    등록시간 : 2014/01/30 13:17:33
    http://todayhumor.com/?programmer_915 모바일
    문자열 패턴 찾기-연습용

    예전에 이스트소프트 이력서 넣고 실기 시험 문제들을 미리 풀어 볼까 해서 만든 예제 입니다.
    서류는 처음부터 통과 못했고 ㅜㅜ

    실기 문제는 문자열 패턴 최대 갯수 찾기였던 것 같습니다.
    회사에서 프로그램 만드는데 4시간 준다고 하던데 막상 그냥 해보니 능력이 모자라 4시간 더 걸렸습니다.
    다른 문제도 풀어볼려구 했는데 떨어졌다고 해서...
    회사가 알긴 아나 봅니다. ㅋㅋ

    연휴라 노트북 정리하다가 지우기 아쉬워서  어디 저장해 놓을 데 없어서 그냥 여기에 올려봅니다.



    #pragma warning(disable: 4996)

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

    int FindMaxPattern(int* dstPos, int* dstLen, const char* sSrc, int lenSrc)
    {
    //char sSrc[]="abcbabdbe";

    int retMax = 0; // 출력용 최대 패턴 길이
    int retCnt = 0; // 출력용 최대 패턴 숫자
    int retLen = 0; // 출력용 최종 패턴 키 길이
    char* retDst = NULL; // 출력용 최종 패턴 시작 위치

    int ptnCnt = 0; // 임시 패턴 숫자
    int ptnMax = 0; // 임시 패턴 최대 길이
    char* ptnKey = NULL; // 패턴 키
    char* ptnBgn = NULL; // 패턴 시작 위치


    int n=0, k=0, i=0;
    int end = 0;
    int lenKey = 0; // 패턴 키 길이

    char sAsc[128]= {0}; // 문자 하나 체크용.

    *dstPos = -1;
    *dstLen = 0;

    if(NULL == sSrc || 1>=lenSrc)
    goto END;


    for(n=0; n<lenSrc/2; ++n) // 입력 문자열 길이의 절반만 수행
    {
    ++lenKey;

    end = lenSrc - lenKey; // 목적지 계산

    for(k=0; k<end; ++k)
    {
    ptnBgn = (char*)(sSrc+k); // Key 생성

    if( ('A' > *ptnBgn || *ptnBgn > 'Z') && //[A-Za-z0-9] 가 아니면 건너뛴다.
    ('a' > *ptnBgn || *ptnBgn > 'z') &&
    ('0' > *ptnBgn || *ptnBgn > '9') &&
    ('A' > *ptnBgn || *ptnBgn > 'z')
    )
    continue;

    if(1 == lenKey)
    {
    if( 0 != sAsc[*ptnBgn])
    continue;

    sAsc[*ptnBgn] = 1;
    }

    ptnKey = ptnBgn; // Key 위치 지정

    ptnCnt = 0; // 패턴 숫자 초기화
    ptnMax = 0;

    for(i= k+lenKey; i< end+1; ) // Key 가 만들어진 위치+ 키 길이 바로 다음부터 찾기 시작
    {
    if(0 == strncmp(sSrc+i, ptnKey, lenKey) )
    {
    ++ptnCnt;
    i += lenKey; // 키를 찾았다면 길이만큼 증가
    }
    else
    ++i; // 찾기 실패. 1증가
    }

    if(0<ptnCnt)
    {
    ++ptnCnt; // 패턴은 2번 이상 나와야 하므로...
    ptnMax = ptnCnt * lenKey;
    }


    //M이 같다면 반복 횟수가 더 많은 반복 문자열을 출력한다.
    //M이 같고 반복 횟수가 동일하다면 앞에 나온 문자열을 출력한다.

    // 이전 보다 큰 패턴을 찾는다.
    if(    retMax < ptnMax
    // || (retMax == ptnMax && ptnLen < lenKey)
    )
    {
    retMax = ptnMax;
    retCnt = ptnCnt;

    retLen = lenKey;
    retDst = ptnKey;
    }

    if(1 == ptnCnt) // 현재 처리하는 문자열에서 패턴이 없으면 다음에도 없음. loop exit
    goto END;

    } // for(k=0; k<end; ++k)

    } // for(n=0; n<lenSrc/2; ++n)


    if(0<retMax)
    {
    *dstPos = retDst - sSrc;
    *dstLen = retLen;
    }

    END:
    return retCnt;
    }

    int PatternTest()
    {
    char* sExam[] =
    {
    "abcde ",
    "12aaaaaaaaaaaaaaaaaaaaaaaaaaaa",
    "ab12ab12abab1212 ",
    NULL,
    };


    for(int n=0; NULL != sExam[n]; ++n)
    {
    char* src    = sExam[n];
    int srcLen = strlen(src);
    int dstPos = -1, dstLen = -1;

    int r = FindMaxPattern(&dstPos, &dstLen, src, srcLen );

    if(0<r)
    {
    printf("Pattern: ");
    fwrite(src+ dstPos, sizeof(char), dstLen, stdout);
    printf(":%d\n", r);
    }

    else
    printf("Pattern: NULL\n");
    }

    return 0;
    }

    int PatternConsole()
    {
    int lenBuf = 1024 * 1024;
    int lenRead = 1;

    char* sSrc = NULL;

    sSrc = (char*)malloc(lenBuf +4);
    memset(sSrc, 0, lenBuf +4);

    while(1)
    {
    printf("패턴 찾기: 종료하려면 \'q\'를 입력하세요.\n");

    memset(sSrc, 0, lenRead);
    fgets(sSrc, lenBuf, stdin);
    lenRead = strlen(sSrc);

    if(2 >= lenRead)
    {
    if('q' == *sSrc) // 프로그램 종료
    break;

    else // 길이가 짧음
    {
    printf("길이가 짧아요.\n");
    continue;
    }
    }

    sSrc[lenRead] = 0; // 개행 문자 처리
    --lenRead;


    int dstPos = -1, dstLen = -1;
    int r = FindMaxPattern(&dstPos, &dstLen, sSrc, lenRead );

    if(0<r)
    {
    printf("Pattern: ");
    fwrite(sSrc+ dstPos, sizeof(char), dstLen, stdout);
    printf(":%d\n", r);
    }

    else
    printf("Pattern: NULL\n\n");
    }


    printf("프로그램 종료\n");

    free(sSrc);

    return 0;
    }


    int PatternFile(int argc, char** argv)
    {
    char* sFileSrc = "F:/in.txt";
    char* sFileDst = "F:/out.txt";

    char* sSrc = NULL;
    FILE* fi = NULL; // source file
    FILE* fo = NULL; // dest file

    int lenBuf = 0;
    int lenRead = 1;

    if(3 > argc)
    {
    printf( "Error:인수가 적습니다. "
    "입력 파일은 %s 출력 파일은 %s로 대처 합니다.\n"
    , sFileSrc, sFileDst
    );

    fi = fopen(sFileSrc, "rt");
    fo = fopen(sFileDst, "wt");
    }
    else
    {
    char* sFileSrc = argv[1];
    char* sFileDst = argv[2];

    fi = fopen(argv[1], "rt"); // source file
    fo = fopen(argv[2], "wt"); // dest file
    }


    if(NULL == fi)
    {
    printf("입력 파일을 열 수 없습니다.\n");
    return 0;
    }


    if(NULL == fo)
    {
    printf("출력 파일을 열 수 없습니다.\n");
    return 0;
    }

    fseek(fi, 0, SEEK_END);
    lenBuf = ftell(fi);
    fseek(fi, 0, SEEK_SET);


    sSrc = (char*)malloc( 4* ( (lenBuf +7)/4 ) );
    memset(sSrc, 0, 4* ( (lenBuf +7)/4 ) );


    lenRead = fread(sSrc, sizeof(char), lenBuf, fi);


    int dstPos = -1, dstLen = -1;
    int r = FindMaxPattern(&dstPos, &dstLen, sSrc, lenRead );


    if(0<r)
    {
    fwrite(sSrc+ dstPos, sizeof(char), dstLen, fo);
    fprintf(fo, ":%d\n", r);

    fwrite(sSrc+ dstPos, sizeof(char), dstLen, stdout);
    printf(":%d\n", r);
    }
    else
    {
    fprintf(fo, "NULL\n");
    printf("Pattern: NULL\n\n");
    }

    free(sSrc);

    fclose(fi);
    fclose(fo);

    return 0;
    }

    // program main
    int main(int argc, char** argv)
    {
    PatternTest();
    //PatternConsole();
    //PatternFile(argc, argv);

    return 0;
    }


    황금비의 꼬릿말입니다
    젊어 고생 늙어 고생. 안되는 사람은 그냥 편안히...

    이 게시물을 추천한 분들의 목록입니다.
    푸르딩딩:추천수 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]
    단축키 운영진에게 바란다(삭제요청/제안) 운영게 게시판신청 자료창고 보류 개인정보취급방침 청소년보호정책 모바일홈