두 이진수의 합을 구하려면 먼저 설정하십시오.
val1 = 11110; val2 = 11100;
이제 sumL을 표시하기 위해 생성된 displaySum() 메서드를 호출합니다.
sum = displaySum(val1, val2);
이진수의 각 비트를 표시하기 위해 메서드에 새 배열을 설정했습니다.
long[] sum = new long[30];
이제 아래 코드와 같이 이진수의 합을 계산하는 전체 코드를 살펴보겠습니다. -
예
using System;
class Demo {
public static void Main(string[] args) {
long val1, val2, sum = 0;
val1 = 11110;
val2 = 11100;
Console.WriteLine("Binary one: "+val1);
Console.WriteLine("Binary two: "+val2);
sum = displaySum(val1, val2);
Console.WriteLine("Sum = {0}", sum);
}
static long displaySum (long val1, long val2) {
long i = 0, rem = 0, res = 0;
long[] sum = new long[30];
while (val1 != 0 || val2 != 0) {
sum[i++] =(val1 % 10 + val2 % 10 + rem) % 2;
rem =(val1 % 10 + val2 % 10 + rem) / 2;
val1 = val1 / 10;
val2 = val2 / 10;
}
if (rem != 0)
sum[i++] = rem;
i = i-1;
while (i >= 0)
res = res * 10 + sum[i--];
return res;
}
} 출력
Binary one: 11110 Binary two: 11100 Sum = 111010