summaryrefslogtreecommitdiff
path: root/462/CH6/EX6.5.b.i/ex_6_5_b_i.sce
blob: 36d63df2520e29ed6825b7413503542a655b51d2 (plain)
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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
// exmple 6.5(b)(i)
clc ;
clear ;
// a=input (”enter the first 8 bit number :”) ;
// b=input (”enter the second 8 bit number : ” ) ;
   a =00011000  ; 
//taking given inputs//
   b =00111010 ;
   for i =1:8
         a1 ( i ) = modulo (a ,10) ;
         a = a /10;
         a = round ( a ) ;
         b1 ( i ) = modulo (b ,10) ;
         b = b /10;
         b = round ( b ) ;
   end
   car (1) =0;
   for i =1:8
//adding both the inputs (binary addition)//
c1 ( i ) = car ( i ) + a1 ( i ) + b1 ( i ) ;
if c1 ( i ) == 2 then
car ( i +1) = 1;

     c1 ( i ) =0;
elseif c1 ( i ) ==3 then
      car ( i +1) = 1;
     c1 ( i ) =1;
else
     car ( i +1) =0;
end
end
c1 (9) = car (9) ;
re =0;
format ( 'v' ,18) ;
for i =1:9
       re = re +( c1 ( i ) *(10^( i -1) ) )
end
printf ( ' The sum of given two binary numbers is %d\n ', re ) ;
q =1;
b =0;
f =0;
a = re ;
while (a >0)
//converting the result to a hexadecimal no//
       r = modulo (a ,10) ;
       b (1 , q ) = r ;
       a = a /10;
       a = floor ( a ) ;
       q = q +1;
end
for m =1: q -1
         c =m -1;
       f = f + b (1 , m ) *(2^ c ) ;
end
hex = dec2hex ( f ) ;
printf ('The sum in hexadecimal notation is %s \n' ,hex ) ;
disp('the sum in decimal form is:')
disp(f)
//displaying result//