aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2020-08-09 16:47:21 +0800
committercrupest <crupest@outlook.com>2020-08-09 16:47:21 +0800
commitaa8c593de0e1f65fddd650896c60a04da8649547 (patch)
tree457f89fe6835529d0d4110381b057265be030b39
parent4ff96415b04bff718047671bcd48ed4c7c0126b0 (diff)
downloadcrupest-aa8c593de0e1f65fddd650896c60a04da8649547.tar.gz
crupest-aa8c593de0e1f65fddd650896c60a04da8649547.tar.bz2
crupest-aa8c593de0e1f65fddd650896c60a04da8649547.zip
import(solutions): Add problem 66 .
-rw-r--r--works/solutions/cpp/66.cpp34
1 files changed, 34 insertions, 0 deletions
diff --git a/works/solutions/cpp/66.cpp b/works/solutions/cpp/66.cpp
new file mode 100644
index 0000000..40ce008
--- /dev/null
+++ b/works/solutions/cpp/66.cpp
@@ -0,0 +1,34 @@
+#include <vector>
+
+using std::vector;
+
+class Solution
+{
+public:
+ vector<int> plusOne(vector<int> &digits)
+ {
+ bool carry = true;
+ const auto end = digits.rend();
+ for (auto iter = digits.rbegin(); carry && iter != end; ++iter)
+ {
+ auto &digit = *iter;
+ digit += 1;
+ if (digit == 10)
+ {
+ digit = 0;
+ carry = true;
+ }
+ else
+ {
+ carry = false;
+ }
+ }
+
+ if (carry)
+ {
+ digits.insert(digits.cbegin(), 1);
+ }
+
+ return digits;
+ }
+};