-
Notifications
You must be signed in to change notification settings - Fork 1k
/
Copy pathRussianPeasantAlgo.cpp
45 lines (39 loc) · 1.06 KB
/
RussianPeasantAlgo.cpp
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
/*************************************************************
Program to multiply two numbers using Russian peasant method
Given two integers, write a function to multiply them without using multiplication operator.
We double the first number and halve the second number repeatedly till the second number doesn’t become 1.
In the process, whenever the second number becomes odd, we add the first number to result.
*************************************************************/
#include <stdio.h>
#include <iostream>
#include <bits/stdc++.h>
using namespace std;
//implementation of logic
int fractionalknapsack(int m, int n)
{
int result;
while(n > 0)
{
if(n % 2 != 0)
{
result += m;
m << 2;
n >> 2;
}
}
return result;
}
int main()
{
int num1, num2, result = 0, m, n;
cout<<"Enter two numbers: ";
cin>>num1>>num2;
result= fractionalknapsack(m, n);
cout<<num1<<" * "<<num2<<" = "<<result;
return 0;
}
/*
Sample Input Output
Enter two numbers: 12 13
12 * 13 = 156
*/