• AI글쓰기 2.1 업데이트
  • AI글쓰기 2.1 업데이트
  • AI글쓰기 2.1 업데이트
  • AI글쓰기 2.1 업데이트
BRONZE
BRONZE 등급의 판매자 자료

시스템프로그래밍 Bits.c 비트연산 비트조작(operation) Bit Level 표현과 조작에 숙달

★ 목적 : Bit Level 표현과 조작에 숙달 총 17개의 문제 ★ 코드에 대한 주석설명으로 비트연산에 대해서 잘 모르는 사람도 잘 이해 할 수 있습니다. ★★★★★★★★★★ [목록] ★★★★★★★★★★★★★★ bitNor : ~(X|Y) 구현 BitAnd :X&Y 구현 minusOne :-1 한 값을 리턴 isEqual :X와 Y가 같으면 1 리턴 bitMask :High low 사이가 1인 값 conditional :same as x ? y : z isLessOrEqual :if x <= y then return 1, else return 0 isNegative :X < 0 이면 1 리턴 isPositive :X > 0 이면 1 리턴 multFiveEights :입력값에 5/8을 곱합(반올림 0) reverseBytes :X 의 바이트를 거꾸로 바꿈 isPower2 :X가 2의 제곱승이면 1 리턴 isNonZero :X가 0이 아니면 1 리턴 bitParity :X가 홀수개의 0을 가지고 있으면 1리턴 satAdd : 2개의 수를 더함 양수 오버플로 발생 – 양수 최대값 음수 오버플로 발생 – 음수 최대값 sm2tc : Convert from sign-magnitude to two`s complement tc2sm : Convert from two`s complement to sign-magnitude ★ 프로그램 주석참고 /* * reverseBytes - reverse the bytes of x * Example: reverseBytes(0x01020304) = 0x04030201 * Legal ops: ! ~ & ^ | + << >> * Max ops: 25 * Rating: 3 */ int reverseBytes(int x) { /* 0xFF FF FF FF 최상위 상위 하위 최하위 */ int Byte1 = (x & 0xFF ) << 24; // 최하위 바이트를 최상위 바이트로 이동 Byte1에 저장 int Byte2 = ((x >> 8 ) & 0xFF ) << 16; // 하위 바이트를 상위 바이트로 이동 Byte2에 저장 int Byte3 = ((x >> 16 ) & 0xFF ) << 8; // 상위 바이트를 하위 바이트로 이동 Byte3에 저장 int Byte4 = ((x >> 24 ) & 0xFF ); // 최상위 바이트를 최하위 바이트로 이동 Byte4에 저장 /* 각 저장된 바이트에 저장된 비트들을 or 연산하여 리턴해준다. */ int result = Byte1 | Byte2 | Byte3 | Byte4; return result; } ★ 과제에 도움될만한 사이트 및 소스코드를 별도 한글 문서로 저장해놨습니다.
11 페이지
한컴오피스
최초등록일 2012.10.04 최종저작일 2010.09
11P 미리보기
시스템프로그래밍 Bits.c 비트연산 비트조작(operation) Bit Level 표현과 조작에 숙달
  • * 본 문서는 한글 2005 이상 버전에서 작성된 문서입니다. 한글 2002 이하 프로그램에서는 열어볼 수 없으니, 한글 뷰어프로그램(한글 2005 이상)을 설치하신 후 확인해주시기 바랍니다.

    미리보기

    소개

    ★ 목적 : Bit Level 표현과 조작에 숙달
    총 17개의 문제

    ★ 코드에 대한 주석설명으로 비트연산에 대해서 잘 모르는 사람도 잘 이해 할 수 있습니다.

    ★★★★★★★★★★ [목록] ★★★★★★★★★★★★★★
    bitNor : ~(X|Y) 구현
    BitAnd :X&Y 구현
    minusOne :-1 한 값을 리턴
    isEqual :X와 Y가 같으면 1 리턴
    bitMask :High low 사이가 1인 값
    conditional :same as x ? y : z
    isLessOrEqual :if x <= y then return 1, else return 0
    isNegative :X < 0 이면 1 리턴
    isPositive :X > 0 이면 1 리턴
    multFiveEights :입력값에 5/8을 곱합(반올림 0)
    reverseBytes :X 의 바이트를 거꾸로 바꿈
    isPower2 :X가 2의 제곱승이면 1 리턴
    isNonZero :X가 0이 아니면 1 리턴
    bitParity :X가 홀수개의 0을 가지고 있으면 1리턴
    satAdd : 2개의 수를 더함
    양수 오버플로 발생 – 양수 최대값
    음수 오버플로 발생 – 음수 최대값
    sm2tc : Convert from sign-magnitude to two`s complement
    tc2sm : Convert from two`s complement to sign-magnitude

    ★ 프로그램 주석참고
    /*
    * reverseBytes - reverse the bytes of x
    * Example: reverseBytes(0x01020304) = 0x04030201
    * Legal ops: ! ~ & ^ | + << >>
    * Max ops: 25
    * Rating: 3
    */
    int reverseBytes(int x) {
    /*
    0xFF FF FF FF
    최상위 상위 하위 최하위
    */
    int Byte1 = (x & 0xFF ) << 24; // 최하위 바이트를 최상위 바이트로 이동 Byte1에 저장
    int Byte2 = ((x >> 8 ) & 0xFF ) << 16; // 하위 바이트를 상위 바이트로 이동 Byte2에 저장
    int Byte3 = ((x >> 16 ) & 0xFF ) << 8; // 상위 바이트를 하위 바이트로 이동 Byte3에 저장
    int Byte4 = ((x >> 24 ) & 0xFF ); // 최상위 바이트를 최하위 바이트로 이동 Byte4에 저장

    /* 각 저장된 바이트에 저장된 비트들을 or 연산하여 리턴해준다. */
    int result = Byte1 | Byte2 | Byte3 | Byte4;

    return result;
    }


    ★ 과제에 도움될만한 사이트 및 소스코드를 별도 한글 문서로 저장해놨습니다.

    목차

    없음

    본문내용

    * isEqual - return 1 if x == y, and 0 otherwise
    * Examples: isEqual(5,5) = 1, isEqual(4,5) = 0
    * Legal ops: ! ~ & ^ | + << >>
    * Max ops: 5
    * Rating: 2
    */
    int isEqual(int x, int y) {
    /*
    If x and y is equl x ^ y == 0,
    is not equl x ^ y == 1.

    so, if isEqual(x,y) is ture , return 1 !(x^y) == 1
    if isEqual(x,y) is false, return 0 !(x^y) == 0
    */

    return !(x^y);
    }


    /*
    * bitMask - Generate a mask consisting of all 1`s
    * lowbit and highbit
    * Examples: bitMask(5,3) = 0x38
    * Assume 0 <= lowbit <= 31, and 0 <= highbit <= 31
    * If lowbit > highbit, then mask should be all 0`s
    * Legal ops: ! ~ & ^ | + << >>
    * Max ops: 16
    * Rating: 3
    */
    int bitMask(int highbit, int lowbit) {

    // Make a high Bitmask
    int highMask = (~0x00) << highbit;

    // Make a Low Bitmask
    int LowMask = (~0x00) << lowbit;

    // Input highbit value is better than lowbit
    int betterHigh = ((highMask ^ LowMask)) | ( 0x01 << highbit );

    // Input value lowbit is better than highbit
    int betterLow = (~0x00 << lowbit);

    // If lowbit > highbit, then mask should be all 0`s
    return betterHigh & betterLow;
    }


    /*
    * conditional - same as x ? y : z
    * Example: conditional(2,4,5) = 4
    * Legal ops: ! ~ & ^ | + << >>
    * Max ops: 16
    * Rating: 3

    참고자료

    · http://read.pudn.com/downloads9/sourcecode/unix_linux/33029/bits-handout/bits.c__.htm
    · http://read.pudn.com/downloads9/sourcecode/unix_linux/33029/bits-handout/bits.c__.htm
    · http://wiki.xeraph.com/wiki.php?BitsManipulation
    · http://nosyu.pe.kr/1473
    · http://cse.unl.edu/~jjohnson/bits.c
  • 자료후기

      Ai 리뷰
      구매한 자료가 제가 필요로 하는 모든 정보를 포함하고 있어, 매우 만족스러웠습니다. 판매자의 자료는 다음에도 다시 이용하고 싶습니다. 정말 감사드립니다.
    • 자주묻는질문의 답변을 확인해 주세요

      해피캠퍼스 FAQ 더보기

      꼭 알아주세요

      • 자료의 정보 및 내용의 진실성에 대하여 해피캠퍼스는 보증하지 않으며, 해당 정보 및 게시물 저작권과 기타 법적 책임은 자료 등록자에게 있습니다.
        자료 및 게시물 내용의 불법적 이용, 무단 전재∙배포는 금지되어 있습니다.
        저작권침해, 명예훼손 등 분쟁 요소 발견 시 고객센터의 저작권침해 신고센터를 이용해 주시기 바랍니다.
      • 해피캠퍼스는 구매자와 판매자 모두가 만족하는 서비스가 되도록 노력하고 있으며, 아래의 4가지 자료환불 조건을 꼭 확인해주시기 바랍니다.
        파일오류 중복자료 저작권 없음 설명과 실제 내용 불일치
        파일의 다운로드가 제대로 되지 않거나 파일형식에 맞는 프로그램으로 정상 작동하지 않는 경우 다른 자료와 70% 이상 내용이 일치하는 경우 (중복임을 확인할 수 있는 근거 필요함) 인터넷의 다른 사이트, 연구기관, 학교, 서적 등의 자료를 도용한 경우 자료의 설명과 실제 자료의 내용이 일치하지 않는 경우
    문서 초안을 생성해주는 EasyAI
    안녕하세요 해피캠퍼스의 20년의 운영 노하우를 이용하여 당신만의 초안을 만들어주는 EasyAI 입니다.
    저는 아래와 같이 작업을 도와드립니다.
    - 주제만 입력하면 AI가 방대한 정보를 재가공하여, 최적의 목차와 내용을 자동으로 만들어 드립니다.
    - 장문의 콘텐츠를 쉽고 빠르게 작성해 드립니다.
    - 스토어에서 무료 이용권를 계정별로 1회 발급 받을 수 있습니다. 지금 바로 체험해 보세요!
    이런 주제들을 입력해 보세요.
    - 유아에게 적합한 문학작품의 기준과 특성
    - 한국인의 가치관 중에서 정신적 가치관을 이루는 것들을 문화적 문법으로 정리하고, 현대한국사회에서 일어나는 사건과 사고를 비교하여 자신의 의견으로 기술하세요
    - 작별인사 독후감
    • EasyAI 무료체험
    해캠 AI 챗봇과 대화하기
    챗봇으로 간편하게 상담해보세요.
    2025년 10월 07일 화요일
    AI 챗봇
    안녕하세요. 해피캠퍼스 AI 챗봇입니다. 무엇이 궁금하신가요?
    12:05 오후