forked from sachuverma/DataStructures-Algorithms
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathMultiply two linked lists.cpp
61 lines (50 loc) · 1.44 KB
/
Multiply two linked lists.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
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
/*
Multiply two linked lists
=========================
Given elements as nodes of the two linked lists. The task is to multiply these two linked lists, say L1 and L2.
Note: The output could be large take modulo 109+7.
Input:
The first line of input contains an integer T denoting the number of test cases. Then T test cases follow, the first line of each test case contains an integer N denoting the size of the first linked list (L1). In the next line are the space separated values of the first linked list. The third line of each test case contains an integer M denoting the size of the second linked list (L2). In the forth line are space separated values of the second linked list.
Output:
For each test case output will be an integer denoting the product of the two linked list.
User Task:
The task is to complete the function multiplyTwoLists() which should multiply the given two linked lists and return the result.
Constraints:
1 <= T <= 100
1 <= N, M <= 100
Example:
Input:
2
2
3 2
1
2
3
1 0 0
2
1 0
Output:
64
1000
Explanation:
Testcase 1: 32*2 = 64.
Testcase 2: 100*10 = 1000.
*/
long long multiplyTwoLists(Node *l1, Node *l2)
{
long long n1 = 0, n2 = 0, ans;
auto temp = l1;
while (temp)
{
n1 = (n1 * 10LL + temp->data) % 1000000007;
temp = temp->next;
}
temp = l2;
while (temp)
{
n2 = (n2 * 10LL + temp->data) % 1000000007;
temp = temp->next;
}
ans = (n1 % 1000000007 * n2 % 1000000007) % 1000000007;
return ans;
}