Как добавить бинарный тип без знака в C? - PullRequest
0 голосов
/ 16 мая 2018

Вот лист, которому я должен следовать https://imgur.com/a/JuLpQZt

Вот мой код на данный момент

#include<stdio.h>
#include<conio.h>
#include<stdlib.h>
#include<windows.h>

void arithmetic();
int ALU(unsigned char operand1, unsigned char operand2, unsigned char control_signals);
int askOperand1();
int askOperand2();
unsigned char operand1;
unsigned char operand2; 
unsigned char control_signals;
const int ACC = 16; //ACC = ACCUMULATOR

int main()
{

    for(;;)
    {
        system("cls");
        ALU(operand2,operand2,control_signals);
    }
    getch();
    return 0;
}

int ALU(unsigned char operand1, unsigned char operand2, unsigned char control_signals)
{
    operand1=askOperand1();
    operand2=askOperand2();

    int pos1,pos2;
    unsigned char bin8_1[]  = "00000000";
    unsigned char bin8_2[]  = "00000000";

    /*OPERAND 1*/
    for (pos1 = 8; pos1 >= 0; --pos1)
    {
        if (operand1 % 2) 
        bin8_1[pos1] = '1';
        operand1 /= 2;
    }
    printf("\n\nBinary Equivalence of Operand 1: %s",bin8_1);

    /*OPERAND 2*/
    for (pos2 = 8; pos2 >= 0; --pos2)
    {
        if (operand2 % 2) 
        bin8_2[pos2] = '1';
        operand2 /= 2;
    }
    printf("\n\nBinary Equivalence of Operand 2: %s",bin8_2);


    /*ARITHMETIC FUNCTIONS*/
    int option, remainder = 0, sum[ACC], k;
    arithmetic();
    scanf("%d",&option);
    switch(option)
    {
        case 1: //ADDITION
             while (bin8_1 != 0 || bin8_2 != 0)
            {
                sum[k++] =(bin8_1 % 10 + bin8_2 % 10 + remainder) % 2;
                remainder =(bin8_1 % 10 + bin8_2 % 10 + remainder) / 2;
                bin8_1 = bin8_1 / 10;
                bin8_2 = bin8_2 / 10;
            }
            if (remainder != 0)
            sum[k++] = remainder;
            --k;
            printf("Sum of two binary numbers: ");
            while (k >= 0)
            printf("%d", sum[k--]);
            break;
        case 2: //SUBTRACTION VIA 2'S COMPLEMENT
            break;
        case 3: //MULTIPLICATION
            break;
        case 4: //DIVISION
            break;
    }

}
int askOperand1()
{
    int ask1;
    printf("\n\nEnter Operand 1(in decimal): ");
    scanf("%d",&ask1);
    if(ask1>255)
    {
        printf("\n\nINVALID! 0-255 ONLY! TRY AGAIN. EXITTING PROGRAM!");
        getch();
        exit(1);
    }
    return ask1;
}
int askOperand2()
{
    int ask2;
    printf("\nEnter Operand 2(in decimal): ");
    scanf("%d",&ask2);
    if(ask2>255)
    {
        printf("\n\nINVALID! 0-255 ONLY! TRY AGAIN. EXITTING PROGRAM!");
        getch();
        exit(1);
    }
    return ask2;
}
void arithmetic()
{
    printf("\n\n");
    printf("[1] ADDITION\n");
    printf("[2] SUBTRACTION\n");
    printf("[3] MULTIPLICATION\n");
    printf("[4] DIVISION\n");
    printf("\nOption: ");
}

Входные данные должны быть десятичными от 0 до 255. И тогда он будет преобразован в двоичный файл. Эти два двоичных файла будут добавлены, а затем выведены 16-битные выходные данные. Я также ничего не знаю о переменной control_signals и не могу спросить об этом моего учителя, потому что он уехал на 1 неделю.

1 Ответ

0 голосов
/ 16 мая 2018

Вы объявили bin8_1 и bin8_2 как unsigned char bin8_#[].
Это означает, что это массив unsigned char.

Затем вы сравниваете этот массив с int.Попробуйте с простым unsigned char.

...