모바일 오유 바로가기
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_5825
    작성자 : 황금비
    추천 : 2
    조회수 : 404
    IP : 121.143.***.81
    댓글 : 0개
    등록시간 : 2014/10/07 18:26:14
    http://todayhumor.com/?programmer_5825 모바일
    심심해서 큐 만들어봄
    아래 어떤 분이 큐 문제 올려서 그냥 만들어 보았습니다.

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

    typedef int              INT;
    typedef unsigned int     UINT;
    #define FALSE 0
    #define TRUE  1

    #define DATA_SIZE 36
    #define MAX_H 25
    #define MAX_QUE (DATA_SIZE * MAX_H)

    #ifdef __cplusplus
    struct TQUEUE
    #else
    typedef struct tagQueue
    #endif
    {
    INT  front; // front index
    INT  rear; // rear index
    INT  count; // stored count
    UINT que[DATA_SIZE * MAX_H]; // que buffer

    #ifdef __cplusplus
    TQUEUE(); // constructor

    void Init(); // initialize the queue
    INT  PushBack(UINT* buf, INT size); // return the copied size to que buffer
    INT  PopFront(UINT* buf, INT size, INT bREMOVE= TRUE); // peek from the que buffer. return the count
    INT  Copy(UINT* buf, INT size); // copy the que to buf. return the copied size
    INT  Size() { return count; } // return the stored data
    #endif

    #ifdef __cplusplus
    };
    #else
    } TQUEUE;
    #endif

    #ifdef __cplusplus
    TQUEUE::TQUEUE()
    {
    front = 0;
    rear  = 0;
    count = 0;
    memset(que, 0, sizeof(UINT)* MAX_QUE);
    }
    #endif

    #ifdef __cplusplus
    void TQUEUE::Init()
    #else
    void Queue_Init(_this)
    TQUEUE* _this;
    #endif
    {
    #ifdef __cplusplus
    TQUEUE* _this  = this;
    #endif

    _this->front = 0;
    _this->rear  = 0;
    _this->count = 0;
    memset(_this->que, 0, sizeof(UINT)* MAX_QUE);
    }

    #ifdef __cplusplus
    int TQUEUE::PushBack(UINT* buf, INT size) // return the copied size to que buffer
    #else
    int Queue_PushBack(_this, buf, size) // return the copied size to que buffer

    TQUEUE* _this;
    UINT* buf;
    INT size;
    #endif
    {
    #ifdef __cplusplus
    TQUEUE* _this  = this;
    #endif

    INT i=0;

    for(i=0; i<size; ++i)
    {
    if(MAX_QUE == _this->count)
    return i;

    *(_this->que+_this->rear) = *(buf + i);
    ++_this->rear; // move the _this->rear index
    _this->rear %= MAX_QUE; // reset the index

    ++_this->count; // increase count
    }

    return i;
    }

    #ifdef __cplusplus
    INT TQUEUE::PopFront(UINT* buf, INT size, INT bREMOVE)
    #else
    INT Queue_PopFront(_this, buf, size, bREMOVE)
    TQUEUE* _this;
    UINT* buf;
    INT size;
    INT bREMOVE;
    #endif
    {
    #ifdef __cplusplus
    TQUEUE* _this  = this;
    #endif

    INT i=0;
    INT t_front = 0;
    INT t_count = 0;

    if(0 == _this->count)
    return 0;

    if(bREMOVE)
    {
    for(i=0; i<size; ++i)
    {
    if(0 == _this->count)
    return i;

    *(buf + i) = *(_this->que + _this->front);
    ++_this->front; // move the rear index
    _this->front %= MAX_QUE; // reset the index

    --_this->count; // increase count
    }

    return i;
    }


    t_front = _this->front;
    t_count = _this->count;
    for(i=0; i<size; ++i)
    {
    if(0 == t_count)
    return i;

    *(buf + i) = *(_this->que + t_front);
    ++t_front; // move the rear index
    t_front %= MAX_QUE; // reset the index

    --t_count; // increase count
    }

    return i;
    }

    #ifdef __cplusplus
    INT TQUEUE::Copy(UINT* buf, INT size)
    #else
    INT Queue_Copy(_this, buf, size)
    TQUEUE* _this;
    UINT* buf;
    INT size;
    #endif
    {
    #ifdef __cplusplus
    TQUEUE* _this  = this;
    #endif

    INT i=0;
    INT t_front = _this->front;
    INT t_count = _this->count;

    for(i=0; i<size; ++i)
    {
    if(0 == t_count)
    return i;

    *(buf + i) = *(_this->que + t_front);
    ++t_front; // move the rear index
    t_front %= MAX_QUE; // reset the index

    --t_count; // increase count
    }

    return i;
    }

    int main(int argc, char** argv)
    {
    INT number;
    INT outnum;
    INT random;

    UINT arr_i[DATA_SIZE+4] ={0};
    UINT arr_o[DATA_SIZE+4] ={0};
    INT  rcv  =0;
    INT  i =0;
    INT  size = 0;

    TQUEUE qh;
    srand((unsigned)time(NULL));

    #ifdef __cplusplus
    qh.Init();
    #else
    Queue_Init(&qh);
    #endif


    for(outnum=0;outnum<10000;outnum++)
    {
    size = 4 + rand()% DATA_SIZE;

    for(number=0;number<size;number++)
    {
    random = rand(); // 난수생성
    arr_i[number]=random%100; // 임시배열에 난수 넣기
    }

    printf("add : %2d :: ", size);
    for(i=0; i<size; ++i)
    printf("%2d ", arr_i[i]);

    printf("\n");


    // test ...
    #ifdef __cplusplus
    qh.PushBack(arr_i, size); // temp를 큐에 넣기
    rcv = qh.PopFront(arr_o, size, TRUE);
    #else
    Queue_PushBack(&qh, arr_i, size); // temp를 큐에 넣기
    rcv = Queue_PopFront(&qh, arr_o, size, TRUE);
    #endif


    printf("peek: %2d :: ", size);
    for(i=0; i<rcv; ++i)
    printf("%2d ", arr_o[i]);

    printf("\n");
    }
    return 0;
    }


    이 게시물을 추천한 분들의 목록입니다.
    [1] 2014/10/07 19:20:48  14.45.***.243  퍼렁곰탱이  561445
    [2] 2014/10/08 03:36:30  220.83.***.160  중학생코더★  552609
    푸르딩딩:추천수 3이상 댓글은 배경색이 바뀝니다.
    (단,비공감수가 추천수의 1/3 초과시 해당없음)

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

    번호 제 목 이름 날짜 조회 추천
    72
    무슨 갤럭시 7 도 아니고 황금비 16/09/22 21:40 90 0
    71
    게임 업계 아재가 게임 프로그램 배우는 분들에게 해주는 도움 안되는 글 [7] 창작글 황금비 16/05/01 01:17 71 11
    70
    지하철 잡상인 - 유머글 아닙니다. [1] 창작글 황금비 16/04/02 10:23 35 0
    69
    러블리즈 가입했습니다. [2] 창작글 황금비 16/02/21 17:18 100 10
    68
    A Tour of C++ 발 번역 [2] 창작글 황금비 16/02/21 10:24 54 11
    67
    프로그래밍, 하는만큼 늡니다. [2] 창작글 황금비 15/06/15 23:06 46 2
    66
    개콘에서 푸리에 급수 황금비 15/03/08 22:19 75 0
    65
    주말이 끝나는 시점에서 심심해서 하나 더 sort [1] 황금비 14/11/02 17:53 41 1
    64
    스트레스 풀겸, 그냥 심심해서 [1] 황금비 14/11/02 15:15 63 0
    심심해서 큐 만들어봄 황금비 14/10/07 18:26 43 2
    62
    아오 빡쳐. [2] 황금비 14/10/05 18:47 20 1
    61
    시리야 사태 [2] 황금비 14/10/04 23:07 82 2
    60
    아오.. 빡쳐... 아오 evo ssang.. [3] 황금비 14/09/24 05:56 167 1
    59
    terminal ide [6] 황금비 14/09/23 01:33 28 0
    58
    암당 [5] 황금비 14/09/22 14:27 99 0
    57
    100만원대 초반 예상 견적 [5] 황금비 14/09/22 09:09 147 1
    56
    나름 자부심 [4] 황금비 14/09/21 23:46 52 0
    55
    90만원대에 많이 추천되는 견적 예상 [5] 황금비 14/09/21 14:36 163 0
    54
    영어지만 대충 표만 봐도 어떻게 바뀌었는지 알수 있겠네요. [2] 황금비 14/09/20 00:01 57 1
    53
    컴퓨터 지름 [5] 황금비 14/09/16 15:36 77 0
    52
    포토샵 스크립트 황금비 14/09/15 20:59 32 1
    51
    디스어셈블리 인텔 opmap, moder/m, sib [2] 황금비 14/09/13 15:35 35 1
    50
    27D850T 삼성 <- 이모니터 어떤가요? [1] 황금비 14/09/07 22:50 55 0
    49
    xor swap [14] 황금비 14/09/04 18:36 23 0
    48
    IHS 없는 뚜따 [10] 황금비 14/09/03 12:36 133 1
    47
    C++ PROGRAMMING LANGUAGE 4th advise만 발번역 [4] 황금비 14/09/01 19:50 33 5
    46
    포인터를 사용한 swap [16] 황금비 14/09/01 10:23 48 0
    45
    포인터 스포일 [21] 황금비 14/08/31 01:42 28 3/4
    44
    제가 사용하는 const, double poiner 입니다. [2] 황금비 14/08/30 02:22 38 1
    43
    모바일 게임 엔진 만드시는 분들 계신지요. [6] 황금비 14/08/26 17:59 29 0
    [1] [2] [3] [4]
    단축키 운영진에게 바란다(삭제요청/제안) 운영게 게시판신청 자료창고 보류 개인정보취급방침 청소년보호정책 모바일홈