#include #include #include "auxiliar.h" #include int bin2dec(char *bin) { int i; int num = 0; int length = strlen(bin); int pos = length - 1; char *aux = (char*) malloc(sizeof(char) * length); strcpy(aux,bin); normalize(&aux,1); for(i = 0; i < length; i++) { if(aux[pos--]) { num += pow(2,i); } } free(aux); return num; } int check_length(char **inputs, uint8_t num_inputs) { int i; int length = strlen(inputs[0]); for(i = 1; i < num_inputs-1; i++) { if(strlen(inputs[i]) != length) { return -1; } } int sel_length = strlen(inputs[num_inputs-1]); if(pow(2,sel_length) < (num_inputs-1)) { return -1; } return length; } int main(int argc, char **argv) { int i; if(argc != 2) { error(); } char *input = argv[1]; if(!strcmp(input,"error")) { error(); } char **inputs = comma_separate(input); if(inputs == NULL) { error(); } int num_inputs = num_occurrences(input,','); int input_length = check_length(inputs,num_inputs); if(input_length == -1) { error(); } int selected = bin2dec(inputs[num_inputs-1]); if(selected >= (num_inputs-1)) { for(i = 0; i < input_length; i++) { printf("0"); } } else { char *result = inputs[selected]; printf("%s",result); } free_mem(inputs,num_inputs); return 0; }