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
- 따라하면서 배우는 C언어
- BFS
- web
- Cleancode
- String
- udemy
- Algorithm
- DP
- JavaScript
- graph
- 백준
- C
- BASIC
- 종만북
- dfs
- Algospot
- 인프런
- Python
- php
- C언어
- programmers
- server
- 따라하며 배우는 C언어
- 따배씨
- BOJ
- 정수론
- 생활코딩
- sorting
- greedy
- Math
Archives
- Today
- Total
몽상실현개발주의
[따배씨] 15.2 이진수를 십진수로 바꾸기 연습문제 본문
따배씨 - 따라하며 배우는 C언어
15강 비트 다루기
15.2 이진수를 십진수로 바꾸기 연습문제
#include <stdio.h>
#include <math.h> // pow()
#include <string.h> // strlen()
#include <stdlib.h> // exit()
unsigned int to_decimal(const char bi[]);
int main()
{
printf("Binary (string) to Decimal conversion\n");
printf("%d\n", to_decimal("00000110"));
printf("%d\n", to_decimal("00010110"));
printf("%d\n", to_decimal("10010100"));
return 0;
}
unsigned int to_decimal(const char bi[]) // unsigned char 범위 0~255
{
const size_t bits = strlen(bi);
// size_t : 시스템에서 값이 포함 할 수 있는 최대 크기의 데이터를 표현하는 타입
unsigned int sum = 0;
for (size_t i = 0; i < bits; i++)
{
if (bi[i] == '1')
sum += (int)pow(2, bits - 1 - i);
else if(bi[i] != '0')
{
printf("Wrong character : %c", bi[i]);
exit(1);
}
}
return sum;
}
이 글의 모든 사진과 내용의 출처는 홍정모 교수님께 있음을 알려드립니다.
http://blog.naver.com/atelierjpro
http://www.inflearn.com/course/following-c
'Language > C' 카테고리의 다른 글
[따배씨] 15.4 비트 단위 논리 연산자 확인해보기 (0) | 2021.07.21 |
---|---|
[따배씨] 15.3 &를 이용하는 십진수 -> 이진수 연습 문제 (0) | 2021.07.21 |
[따배씨] 15.1 비트단위 논리 연산자 (0) | 2021.07.20 |
[따배씨] 4.26 함수 포인터의 배열 연습문제 (0) | 2021.07.14 |
[따배씨] 14.25 qsort() 함수 포인터 연습문제 (0) | 2021.07.14 |
Comments