我是靠谱客的博主 成就蛋挞,这篇文章主要介绍二进制十六位加法器,现在分享给大家,希望可以做个参考。

最近心血来潮,学习了二进制加法器。

代码:

复制代码
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
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
/** 二进制16位加法器(原理) * 学习于:https://blog.csdn.net/qq_28893679/article/details/105990487 */ #include<iostream> #include<stack> using namespace std; int s1,co1,s2,co2; stack<int>ans; void bplus(int a,int b){//半加器 s1=a xor b; co1=a and b; } void qplus(int ci,int a,int b)//全加器 { int co; bplus(a,b); co=co1; bplus(ci,s1); co2=co or co1; s2=s1; } void _plus(int a1,int a2,int a3,int a4,int a5,int a6,int a7,int a8,int a9,int a10,int a11,int a12,int a13,int a14,int a15,int a16,int b1,int b2,int b3,int b4,int b5,int b6,int b7,int b8,int b9,int b10,int b11,int b12,int b13,int b14,int b15,int b16) {//16位加法 qplus(0,a16,b16); ans.push(s2); qplus(co2,a15,b15); ans.push(s2); qplus(co2,a14,b14); ans.push(s2); qplus(co2,a13,b13); ans.push(s2); qplus(co2,a12,b12); ans.push(s2); qplus(co2,a11,b11); ans.push(s2); qplus(co2,a10,b10); ans.push(s2); qplus(co2,a9,b9); ans.push(s2); qplus(co2,a8,b8); ans.push(s2); qplus(co2,a7,b7); ans.push(s2); qplus(co2,a6,b6); ans.push(s2); qplus(co2,a5,b5); ans.push(s2); qplus(co2,a4,b4); ans.push(s2); qplus(co2,a3,b3); ans.push(s2); qplus(co2,a2,b2); ans.push(s2); qplus(co2,a1,b1); ans.push(s2); } int main() { int a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12,a13,a14,a15,a16,b1,b2,b3,b4,b5,b6,b7,b8,b9,b10,b11,b12,b13,b14,b15,b16,n,m; cin>>n>>m; cout<<n<<'+'<<m<<'='; a16=n%10; n/=10; b16=m%10; m/=10; a15=n%10; n/=10; b15=m%10; m/=10; a14=n%10; n/=10; b14=m%10; m/=10; a13=n%10; n/=10; b13=m%10; m/=10; a12=n%10; n/=10; b12=m%10; m/=10; a11=n%10; n/=10; b11=m%10; m/=10; a10=n%10; n/=10; b10=m%10; m/=10; a9=n%10; n/=10; b9=m%10; m/=10; a8=n%10; n/=10; b8=m%10; m/=10; a7=n%10; n/=10; b7=m%10; m/=10; a6=n%10; n/=10; b6=m%10; m/=10; a5=n%10; n/=10; b5=m%10; m/=10; a4=n%10; n/=10; b4=m%10; m/=10; a3=n%10; n/=10; b3=m%10; m/=10; a2=n%10; n/=10; b2=m%10; m/=10; a1=n%10; n/=10; b1=m%10; m/=10; _plus(a1,a2,a3,a4,a5,a6,a7,a8,a9,a10,a11,a12,a13,a14,a15,a16,b1,b2,b3,b4,b5,b6,b7,b8,b9,b10,b11,b12,b13,b14,b15,b16); cout<<co2; for(int i=0;i<16;i++) { cout<<ans.top(); ans.pop(); } cout<<endl; main(); }

输入两个二进制数,输出这两个二进制数的相加加结果

最后

以上就是成就蛋挞最近收集整理的关于二进制十六位加法器的全部内容,更多相关二进制十六位加法器内容请搜索靠谱客的其他文章。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(107)

评论列表共有 0 条评论

立即
投稿
返回
顶部