-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathplus_one.dart
142 lines (116 loc) · 3.36 KB
/
plus_one.dart
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
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
/*
-* Plus One *-
You are given a large integer represented as an integer array digits, where each digits[i] is the ith digit of the integer.
The digits are ordered from most significant to least significant in left-to-right order.
The large integer does not contain any leading 0's.
Increment the large integer by one and return the resulting array of digits.
Example 1:
Input: digits = [1,2,3]
Output: [1,2,4]
Explanation: The array represents the integer 123.
Incrementing by one gives 123 + 1 = 124.
Thus, the result should be [1,2,4].
Example 2:
Input: digits = [4,3,2,1]
Output: [4,3,2,2]
Explanation: The array represents the integer 4321.
Incrementing by one gives 4321 + 1 = 4322.
Thus, the result should be [4,3,2,2].
Example 3:
Input: digits = [9]
Output: [1,0]
Explanation: The array represents the integer 9.
Incrementing by one gives 9 + 1 = 10.
Thus, the result should be [1,0].
Constraints:
1 <= digits.length <= 100
0 <= digits[i] <= 9
digits does not contain any leading 0's.
*/
void main() {
final List<int> digits = [9];
final a = D().plusOne(digits);
print(a);
}
class A {
// Runtime: 449 ms, faster than 47.37% of Dart online submissions for Plus One.
// Memory Usage: 143.3 MB, less than 26.32% of Dart online submissions for Plus One.
List<int> plusOne(List<int> digits) {
int index = digits.length - 1;
List<int> newItems = digits.toList();
while (index >= 0) {
if (digits[index] < 9) {
newItems[index] = newItems[index] + 1;
if (index < (digits.length - 1)) {
newItems.replaceRange(index + 1, digits.length,
List.generate(digits.length - index - 1, (_) => 0));
}
break;
} else if (digits[index] == 9 && index == 0) {
newItems.replaceRange(index, digits.length,
List.generate(digits.length - index, (_) => 0));
newItems.insert(0, 1);
break;
} else {
index--;
}
}
return newItems;
}
}
class B {
// Runtime: 621 ms, faster than 5.26% of Dart online submissions for Plus One.
// Memory Usage: 142.1 MB, less than 81.58% of Dart online submissions for Plus One.
List<int> plusOne(List<int> digits) {
int size = digits.length - 1;
if (digits[size] < 9) {
digits[size]++;
return digits;
}
for (int i = size; i >= 0; i--) {
if (i == 0 && digits[0] == 9) {
digits.removeAt(i);
digits.insert(0, 1);
digits.insert(1, 0);
return digits;
} else if (size >= 1 && digits[i - 1] < 9) {
digits[i - 1]++;
digits.removeAt(i);
digits.insert(i, 0);
return digits;
} else {
digits.removeAt(i);
digits.insert(i, 0);
}
}
return [];
}
}
class C {
// Runtime: 510 ms, faster than 21.05% of Dart online submissions for Plus One.
// Memory Usage: 142.3 MB, less than 65.79% of Dart online submissions for Plus One.
List<int> plusOne(List<int> digits) {
int n = digits.length;
int i = n - 1;
while (i >= 0) {
if (digits[i] + 1 == 10)
digits[i] = 0;
else {
digits[i] = digits[i] + 1;
return digits;
}
i--;
}
digits.insert(digits[0], 1);
return digits;
}
}
class D {
List<int> plusOne(List<int> digits) {
return (int.parse(digits.join('')) + 1)
.toString()
.split('')
.map((e) => int.parse(e))
.toList();
}
}