aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTa180m2019-07-16 17:46:47 -0400
committerGitHub2019-07-16 17:46:47 -0400
commita1240210e0aa5759bcb224d3ef04e93dc0f683cf (patch)
tree446e57b29d654d8c7b7ddea0062a77483ff15566
parente0e8c2a9927132a649a26c5de0c46c7e0796a911 (diff)
Create nochange.cpp
-rw-r--r--2013/November/Gold/nochange.cpp41
1 files changed, 41 insertions, 0 deletions
diff --git a/2013/November/Gold/nochange.cpp b/2013/November/Gold/nochange.cpp
new file mode 100644
index 0000000..9ba1958
--- /dev/null
+++ b/2013/November/Gold/nochange.cpp
@@ -0,0 +1,41 @@
+#include <algorithm>
+#include <iostream>
+using namespace std;
+
+int v[20], p[100005] = { 0 }, DP[1 << 16];
+
+inline int sum(int i, int j) { return p[j + 1] - p[i]; }
+
+int main() {
+ int K, N; cin >> K >> N;
+ for (int i = 0; i < K; i++) cin >> v[i];
+ for (int i = 0; i < N; i++) {
+ int c; cin >> c;
+ p[i + 1] = c + p[i];
+ }
+
+ for (int i = 0; i < (1 << K); i++) {
+ if (DP[i] < N) {
+ for (int j = 0; j < K; j++) {
+ if ((i & 1 << j) == 0) {
+ int l = DP[i], h = N;
+ while (l + 1 < h) {
+ int m = (l + h) / 2;
+ sum(DP[i], m) > v[j] ? h = m : l = m;
+ }
+ DP[i ^ 1 << j] = max(l + 1, DP[i ^ 1 << j]);
+ }
+ }
+ }
+ }
+
+ int ans = -1;
+ for (int i = 0; i < (1 << K); i++) {
+ if (DP[i] == N) {
+ int sum = 0;
+ for (int j = 0; j < K; j++) if ((i & 1 << j) == 0) sum += v[j];
+ ans = max(sum, ans);
+ }
+ }
+ cout << ans << endl;
+}