Binário para decimal
Publicado por Rick 23/10/2006
[ Hits: 9.410 ]
Já vi alguns algoritmos de conversão de binário para decimal, mas muito mais complexos que este. Eu queira desenvolver um que utilizasse o método do cálculo natural, exemplo: 100 em binário:
(1 x 2^2) + (0 x 2^1) + (0 x 2^0) = 4
Acho que ficou bom...
/*ALGORITMO BINARIO-> DECIMAL POR OPTIMAL (optimal2600@yahoo.com.br)*/
#include <stdio.h>
#include <stdlib.h>
int potc(int num, int pot)
{
int x, old;
old=num;
if (pot==0) return 1;
for(x=1;x<pot;x++) {
num = num*old;
}
return num;
}
int main(void)
{
char mat_str[8][5];
int mtr[8], numero[8], dig, dec=0, x, y;
system("clear");
printf("Numero de digitos: "); scanf("%d", &dig);
__fpurge(stdin);
printf("Binario: ");
y=dig-1;
for (x=0;x<dig;x++) {
mat_str[x][0]=getchar();
fflush(stdin);
}
for (x=0;x<dig;x++) {
if (mat_str[x][0] != '0' && mat_str[x][0] != '1') {
printf("Apenas numeros binarios!!!\n\n");
exit(1);
}
}
for (x=0;x<dig;x++) mat_str[x][1]='\n';
for (x=0;x<dig;x++) mtr[x]=atoi(mat_str[x]);
for (x=0;x<dig;x++) {
numero[x] = (mtr[x] * potc(2, y));
y--;
}
for (x=0;x<dig;x++) dec = dec + numero[x];
printf("Decimal %d\n", dec);
return(0);
}
Decimal ( 8 bits ) para binário
Funções de comparação de String
KDE Plasma - porque pode ser a melhor opção de interface gráfica
Gentoo: detectando impressoras de rede e como fixar uma impressora por IP
Como o GNOME conseguiu o feito de ser preterido por outras interfaces gráficas
Por que sua empresa precisa de uma PKI (e como automatizar EMISSÕES de certificados via Web API)
Instalando NoMachine no Gentoo com Systemd (acesso Remoto em LAN)
Gentoo: Trocando wpa_supplicant pelo iwd no NetworkManager (Systemd)
Instalar Linux em notebook Sony Vaio VPCEG13EB (10)
Vou destruir sua infância:) (6)
Quando vocês pararam de testar distros? (24)









