Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
Tags
- DP
- Algorithm
- 따라하면서 배우는 C언어
- BASIC
- Math
- greedy
- 따라하며 배우는 C언어
- 종만북
- udemy
- Cleancode
- 정수론
- 생활코딩
- sorting
- 인프런
- C
- graph
- JavaScript
- Algospot
- String
- 백준
- programmers
- BFS
- dfs
- Python
- php
- web
- server
- C언어
- 따배씨
- BOJ
Archives
- Today
- Total
몽상실현개발주의
[따배씨] 15.3 &를 이용하는 십진수 -> 이진수 연습 문제 본문
따배씨 - 따라하며 배우는 C언어
15강 비트 다루기
15.3 &를 이용하는 십진수 -> 이진수 연습 문제
#include <stdio.h>
#include <math.h> // pow()
#include <string.h> // strlen()
#include <stdlib.h> // exit()
#include <stdbool.h>
unsigned char to_decimal(const char bi[]);
void print_binary(const unsigned char num);
int main()
{
unsigned char i = to_decimal("01000110");
unsigned char mask = to_decimal("00000101");
print_binary(i);
// Decimal 70 == Bianry 01000110
print_binary(mask);
// Decimal 5 == Bianry 00000101
print_binary(i & mask);
// Decimal 4 == Bianry 00000100
return 0;
}
unsigned char to_decimal(const char bi[])
{
const size_t L = strlen(bi);
unsigned sum = 0;
for (size_t i = 0; i < L; i++)
{
if (bi[i] == '1')
sum += (int)pow(2, L - 1 - i);
}
return sum;
}
void print_binary(const unsigned char num)
{
printf("Decimal %3d \t== Bianry ", num);
const size_t bits = sizeof(num) * 8;
for (size_t i = 0; i < bits; i++)
{
const unsigned char mask = (unsigned char)pow((double)2, (double)(bits - 1 - i));
if ((num & mask) == mask)
// 2진 수의 자리수를 검사하는 mask 변수를 만들어 이진수의 자리수 bit 연산
printf("%d", 1);
else
printf("%d", 0);
}
printf("\n");
}
이 글의 모든 사진과 내용의 출처는 홍정모 교수님께 있음을 알려드립니다.
'Language > C' 카테고리의 다른 글
[따배씨] 15.5 2의 보수 표현법 확인해보기 (0) | 2021.07.23 |
---|---|
[따배씨] 15.4 비트 단위 논리 연산자 확인해보기 (0) | 2021.07.21 |
[따배씨] 15.2 이진수를 십진수로 바꾸기 연습문제 (0) | 2021.07.20 |
[따배씨] 15.1 비트단위 논리 연산자 (0) | 2021.07.20 |
[따배씨] 4.26 함수 포인터의 배열 연습문제 (0) | 2021.07.14 |
Comments