C ++程序实现俄罗斯农民增收乘法
俄罗斯农民增收算法将两个数字相乘。这是计算两个长整数相乘的快速算法。
算法
Begin
Russianpeasant(num1, num2)
Int result=0
while (num2 > 0)
if (num2 and 1)
result = result + n;
num1= num1 left shift 1;
num2= num2left shift 1;
return result
End范例程式码
#include <iostream>
using namespace std;
unsigned int russianPeasant(unsigned int n, unsigned int m) {
int result = 0;
while (m > 0) {
if (m & 1)
result = result + n;
n = n << 1;
m = m >> 1;
}
return result;
}
int main() {
cout << russianPeasant(10, 20) << endl;
cout << russianPeasant(7, 6) << endl;
return 0;
}输出结果
200 42
热门推荐
10 对患者生日祝福语简短
11 结婚祝福语简短装备
12 周岁祝福语学生文案简短
13 订婚领证祝福语简短精辟
14 导师获奖祝福语大全简短
15 新婚购房祝福语简短精辟
16 牛年祝福语简短的爱人
17 送芒果的祝福语简短
18 送给学长毕业祝福语简短