-
-
Notifications
You must be signed in to change notification settings - Fork 14
/
Copy pathContinuous_Subarray_Sum_Multiple_K.cpp
89 lines (62 loc) · 3.02 KB
/
Continuous_Subarray_Sum_Multiple_K.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
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
/*
* @lc app=leetcode id=523 lang=cpp
*
* [523] Continuous Subarray Sum
*/
// @lc code=start
class Solution {
public:
bool checkSubarraySum(vector<int>& nums, int k) {
//Questions to ask the interviewer -
//1. So you said k is an integer? Can the k be equal to 0? Can it be n-ve?
// ANS - k can be positive, zero or negative - consider all cases !
// Positive case - [23, 2, 4, 6, 7], k=6; ANS = true
//Negative Case - [23,2,4,6,7], k= -6; ANS = true (Since n=-1 and -1*-6=6)
//Zero Case - [0,0], k=0; ANS = true
//2. 'n' can be anything right? positive, negative and zero
//Explanation of algorithm to interviewer -
//A proof sketch:
// Suppose sum_i represents the running sum starting from index 0 and ending at i
// once we find a mod that has been seen, say modk, we have:
// current one: sum_i = m*k + modk
// previous one: sum_j = n*k + modk
// Thus,
// sum_i - sum_j = (m - n) *k
//so if two runningSum mod k have the same values, then when they are subtracted, they are bound to be multiples of k
//base checking - first check if the size of the array is less than 2
if(nums.size()<2)
return false;
//Create a hashmap of the running_sum remainder and it's respective index
unordered_map<int, int> mp;
//Why to insert <0,-1> for the hashmap
// <0,-1> can allow it to return true when the runningSum%k=0,
//for example [1,2,3] is input and k=6
//then the remainders are [ 1,3,0] i.e runningSum = runningSum%k
//now 1+2+3=6 which is actually a multiple of 6 and hence 0 should be stored in the hashmap
//ok - but why -1?
//-1 is good for storing for 0 because - it will remove the case where we consider only the first element which alone may be a multiple as 0-(-1) is not greater than 1
// In addition, it also avoids the first element of the array is the multiple of k, since 0-(-1)=1 is not greater than 1.
mp[0]=-1;
int runningSum=0;
for(int i=0;i<nums.size();i++)
{
runningSum+=nums[i];
if(k!=0)
runningSum = runningSum%k;
//check if the runningsum already exists in the hashmap
if(mp.find(runningSum)!=mp.end())
{
//if it exists, then the current location minus the previous location must be greater than1
if(i-mp[runningSum]>1)
return true;
}
else
{
//otherwise if the current runningSum doesn't exist in the hashmap, then store it as it maybe used later on
mp[runningSum]=i;
}
}
return false;
}
};
// @lc code=end