aboutsummaryrefslogtreecommitdiff
path: root/challenge-160/deadmarshal/cpp/ch-2.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'challenge-160/deadmarshal/cpp/ch-2.cpp')
-rw-r--r--challenge-160/deadmarshal/cpp/ch-2.cpp34
1 files changed, 34 insertions, 0 deletions
diff --git a/challenge-160/deadmarshal/cpp/ch-2.cpp b/challenge-160/deadmarshal/cpp/ch-2.cpp
new file mode 100644
index 0000000000..79ab7736f6
--- /dev/null
+++ b/challenge-160/deadmarshal/cpp/ch-2.cpp
@@ -0,0 +1,34 @@
+#include<iostream>
+#include<vector>
+#include<numeric>
+
+int equilibrium_index(const std::vector<int>& vec)
+{
+ int left = 0, right = std::accumulate(vec.begin(), vec.end(), 0);
+ int ret = -1;
+ for(std::size_t i = 0; i < vec.size(); ++i)
+ {
+ right -= vec[i];
+ if(left == right)
+ {
+ ret = i;
+ break;
+ }
+ left += vec[i];
+ }
+ return ret;
+}
+
+int main()
+{
+ std::vector<int> vec{1,3,5,7,9};
+ std::cout << equilibrium_index(vec) << '\n';
+
+ vec = {1,2,3,4,5};
+ std::cout << equilibrium_index(vec) << '\n';
+
+ vec = {2,4,2};
+ std::cout << equilibrium_index(vec) << '\n';
+
+ return 0;
+}