A. Find a Numbernode
Solved By 2017212212083ios
題意:$找一個最小的n使得n % d == 0 而且 n 的每一位數字加起來之和爲s$c++
思路:服務器
定義一個二元組$<d, s>$ 表示當前狀態模d的值,以及每一位加起來的值ide
跑最短路,從$<0, 0> 跑到 <0, s>$ui
1 #include<bits/stdc++.h> 2 3 using namespace std; 4 5 const int maxn = 1e5 + 10; 6 const int INF = 0x3f3f3f3f; 7 #define N 510 8 #define M 5010 9 10 int d, s, cnt; 11 char ans[maxn]; 12 int dis[N][M]; 13 int inq[N][M]; 14 int vis[N][M]; 15 16 struct node{ 17 int remind; 18 int sum; 19 node(){} 20 node(int remind, int sum) :remind(remind), sum(sum){} 21 }; 22 23 void Init() 24 { 25 cnt = -1; 26 memset(inq, 0, sizeof inq); 27 memset(dis, 0x3f, sizeof dis); 28 memset(vis, 0, sizeof vis); 29 } 30 31 void BFS() 32 { 33 queue<node>q; 34 dis[0][0] = 0; 35 q.push(node(0, 0)); 36 inq[0][0] = 1; 37 while(!q.empty()) 38 { 39 node st = q.front(); 40 q.pop(); 41 inq[st.remind][st.sum] = 0; 42 for(int i = 0; i < 10; ++i) 43 { 44 node now = node((st.remind * 10 + i) % d, st.sum + i); 45 if(now.sum > s) break; 46 if(dis[now.remind][now.sum] > dis[st.remind][st.sum] + 1) 47 { 48 dis[now.remind][now.sum] = dis[st.remind][st.sum] + 1; 49 if(!inq[now.remind][now.sum]) 50 { 51 inq[now.remind][now.sum] = 1; 52 q.push(now); 53 } 54 } 55 } 56 } 57 } 58 59 int DFS(int D,int S) 60 { 61 if(D == 0 && S == s) return 1; 62 for(int i = 0; i < 10; ++i) 63 { 64 int td = (D * 10 + i) % d; 65 int ts = S + i; 66 if(ts > s) break; 67 if(vis[td][ts]) continue; 68 if(dis[D][S] + 1 != dis[td][ts]) continue; 69 ans[++cnt] = i; 70 if(DFS(td, ts)) return 1; 71 --cnt; 72 } 73 vis[D][S] = 1; 74 return 0; 75 } 76 77 int main() 78 { 79 while(~scanf("%d %d", &d, &s)) 80 { 81 Init(); 82 BFS(); 83 if(dis[0][s] == INF) 84 { 85 puts("-1"); 86 continue; 87 } 88 DFS(0, 0); 89 for(int i = 0; i <= cnt; ++i) printf("%d", ans[i]); 90 puts(""); 91 } 92 return 0; 93 }
B. Berkomnadzorspa
Unsolved.3d
C. Cloud Computingcode
Solved By Dup4blog
題意:
有一我的須要租用服務器,一共須要n天,天天要k個,供應商會提供一些供應方案,用四元組$<l, r, c, p>$ 表示方案。
$l r 表示 供應的區間, c 表示l, r 區間內天天最多供應c個,p 表示每一個服務器的價格$
思路:
考慮用線段樹維護 兩個值 Min 和 cnt 分別表示區間內最少的服務器須要個數以及區間內還須要購買服務器的天數
對於供應方案,按價格排序以後,從小到大枚舉,對於每一個方案的$l, r$
若是這個區間內全部還須要購買服務器的天中的 須要購買服務器的數量的最小值都 $> c$ 那麼直接區間減便可。
不然 先丟出不符合的,改成INF 再丟進去,標記爲再也不須要購買服務器,並加上貢獻,每一個點最多丟出一次。
時間複雜度 $O(mlog^n + nlog^n)$
1 #include <bits/stdc++.h> 2 using namespace std; 3 4 #define ll long long 5 #define INF 0x3f3f3f3f 6 #define N 1000010 7 int n, k, m; 8 struct qnode 9 { 10 int l, r, c, p; 11 qnode () {} 12 qnode (int l, int r, int c, int p) : l(l), r(r), c(c), p(p) {} 13 void scan() { scanf("%d%d%d%d", &l, &r, &c, &p); } 14 bool operator < (const qnode &r) const { return p < r.p; } 15 }que[N]; 16 17 struct SEG 18 { 19 int lazy[N << 2], Min[N << 2], pos[N << 2], cnt[N << 2]; 20 struct node 21 { 22 int lazy, Min, pos, cnt; 23 node () {} 24 node (int lazy, int Min, int pos, int cnt) : lazy(lazy), Min(Min), pos(pos), cnt(cnt) {} 25 void init() { lazy = 0; Min = INF; pos = 0; cnt = 0; } 26 node operator + (const node &r) const 27 { 28 node res = node(0, INF, 0, 0); 29 res.cnt = cnt + r.cnt; 30 if (Min < r.Min) 31 { 32 res.Min = Min; 33 res.pos = pos; 34 } 35 else 36 { 37 res.Min = r.Min; 38 res.pos = r.pos; 39 } 40 return res; 41 } 42 }a[N << 2], res; 43 void build(int id, int l, int r) 44 { 45 a[id] = node(0, INF, 0, 0); 46 if (l == r) 47 { 48 a[id] = node(0, k, l, 1); 49 return; 50 } 51 int mid = (l + r) >> 1; 52 build(id << 1, l, mid); 53 build(id << 1 | 1, mid + 1, r); 54 a[id] = a[id << 1] + a[id << 1 | 1]; 55 } 56 void change(int id, int lazy) 57 { 58 a[id].lazy += lazy; 59 a[id].Min += lazy; 60 } 61 void pushdown(int id) 62 { 63 if (!a[id].lazy) return; 64 change(id << 1, a[id].lazy); 65 change(id << 1 | 1, a[id].lazy); 66 a[id].lazy = 0; 67 } 68 void update(int id, int l, int r, int ql, int qr, int val) 69 { 70 if (l >= ql && r <= qr) 71 { 72 a[id].Min += val; 73 a[id].lazy += val; 74 return; 75 } 76 pushdown(id); 77 int mid = (l + r) >> 1; 78 if (ql <= mid) update(id << 1, l, mid, ql, qr, val); 79 if (qr > mid) update(id << 1 | 1, mid + 1, r, ql, qr, val); 80 a[id] = a[id << 1] + a[id << 1 | 1]; 81 } 82 void update(int id, int l, int r, int pos) 83 { 84 if (l == r) 85 { 86 a[id].Min = INF; 87 a[id].cnt = 0; 88 return; 89 } 90 pushdown(id); 91 int mid = (l + r) >> 1; 92 if (pos <= mid) update(id << 1, l, mid, pos); 93 else update(id << 1 | 1, mid + 1, r, pos); 94 a[id] = a[id << 1] + a[id << 1 | 1]; 95 } 96 void query(int id, int l, int r, int ql, int qr) 97 { 98 if (l >= ql && r <= qr) 99 { 100 res = res + a[id]; 101 return; 102 } 103 pushdown(id); 104 int mid = (l + r) >> 1; 105 if (ql <= mid) query(id << 1, l, mid, ql, qr); 106 if (qr > mid) query(id << 1 | 1, mid + 1, r, ql, qr); 107 a[id] = a[id << 1] + a[id << 1 | 1]; 108 } 109 }seg; 110 111 int main() 112 { 113 while (scanf("%d%d%d", &n, &k, &m) != EOF) 114 { 115 for (int i = 1; i <= m; ++i) que[i].scan(); 116 sort(que + 1, que + 1 + m); 117 seg.build(1, 1, n); 118 ll res = 0; 119 for (int i = 1, l, r, c, p; i <= m; ++i) 120 { 121 l = que[i].l, r = que[i].r, c = que[i].c, p = que[i].p; 122 while (1) 123 { 124 seg.res.init(); 125 seg.query(1, 1, n, l, r); 126 if (seg.res.cnt == 0) break; 127 if (seg.res.Min <= c) 128 { 129 res += (ll)p * seg.res.Min; 130 seg.update(1, 1, n, seg.res.pos); 131 } 132 else 133 { 134 res += (ll)p * seg.res.cnt * c; 135 seg.update(1, 1, n, l, r, -c); 136 break; 137 } 138 } 139 } 140 printf("%lld\n", res); 141 } 142 return 0; 143 }
D. Garbage Disposal
水。
1 #include<bits/stdc++.h> 2 3 using namespace std; 4 5 typedef long long ll; 6 7 int main() 8 { 9 ll n, k; 10 while(~scanf("%lld %lld", &n, &k)) 11 { 12 ll ans = 0; 13 ll res = 0; 14 for(int i = 1; i <= n; ++i) 15 { 16 ll x; 17 scanf("%lld", &x); 18 if(res > 0) 19 { 20 res += x; 21 if(res >= k) 22 { 23 ans += res / k; 24 res %= k; 25 } 26 else 27 { 28 res = 0; 29 ans++; 30 } 31 } 32 else 33 { 34 res += x; 35 ans += res / k; 36 res %= k; 37 } 38 } 39 if(res) 40 { 41 ans += res % k == 0 ? res / k : res / k + 1; 42 } 43 printf("%lld\n", ans); 44 } 45 return 0; 46 }
E. Getting Deals Done
Solved By 2017212212083 & Dup4
題意:
有一個任務序列,每一個任務有一個完成時間,在作任務的時候有這樣一個規則,定義一個d,對於全部時間小於等於d的任務都要作,而且每作完m個,都要休息,休息時間爲這m個任務的總時間,若是一個任務作不完,這個任務不算數。給出一個總時間T, n, m
以及每一個任務的時間,求最大的任務數,以及d
思路:
二分任務數x, 顯然咱們要作的任務是排序後前x個,將d設爲第x個的時間,按規則遍歷看是否合法便可。
1 #include <bits/stdc++.h> 2 using namespace std; 3 4 #define ll long long 5 #define N 200010 6 int t, n, m; ll T; 7 int p[N], b[N]; 8 9 bool check(int x) 10 { 11 int dd = p[x]; 12 ll tmp = 0, TT = T; int cnt = 0, tot = 0; 13 for (int i = 1; i <= n; ++i) if (b[i] <= dd) 14 { 15 if (TT - b[i] >= 0) 16 { 17 ++cnt; TT -= b[i]; 18 tmp += b[i]; 19 ++tot; 20 } 21 else return tot >= x; 22 if (cnt == m) 23 { 24 cnt = 0; 25 TT -= tmp; 26 tmp = 0; 27 } 28 } 29 if (tot >= x) 30 { 31 return true; 32 } 33 return false; 34 } 35 36 int main() 37 { 38 scanf("%d", &t); 39 while (t--) 40 { 41 scanf("%d%d%lld", &n, &m, &T); 42 for (int i = 1; i <= n; ++i) scanf("%d", p + i), b[i] = p[i]; 43 sort(p + 1, p + 1 + n); 44 p[0] = T; 45 int l = 0, r = n, res = -1; 46 while (r - l >= 0) 47 { 48 int mid = (l + r) >> 1; 49 if (check(mid)) 50 { 51 res = mid; 52 l = mid + 1; 53 } 54 else 55 r = mid - 1; 56 } 57 printf("%d %d\n", res, p[res]); 58 } 59 return 0; 60 }
F. Debate
水。
1 #include <bits/stdc++.h> 2 using namespace std; 3 4 #define N 400010 5 int n, a[N], cnt[4]; 6 priority_queue <int> pq[4]; 7 8 void init() 9 { 10 memset(cnt, 0, sizeof cnt); 11 for (int i = 0; i < 4; ++i) while (!pq[i].empty()) pq[i].pop(); 12 } 13 14 int main() 15 { 16 while (scanf("%d", &n) != EOF) 17 { 18 init(); int res = 0; 19 for (int i = 1, x; i <= n; ++i) 20 { 21 scanf("%02d%d", &x, a + i); 22 if (x == 11) x = 3; 23 else if (x == 10) x = 2; 24 ++cnt[x]; 25 if (x == 3) res += a[i]; 26 else pq[x].push(a[i]); 27 } 28 int limit = min(cnt[1], cnt[2]); 29 for (int i = 1; i <= 2; ++i) for (int j = 0; j < limit; ++j) 30 { 31 res += pq[i].top(); pq[i].pop(); 32 } 33 for (int i = 1; i <= 2; ++i) while (!pq[i].empty()) 34 { 35 pq[0].push(pq[i].top()); pq[i].pop(); 36 } 37 limit = min(cnt[3], (int)pq[0].size()); 38 for (int i = 0; i < limit; ++i) 39 { 40 res += pq[0].top(); pq[0].pop(); 41 } 42 printf("%d\n", res); 43 } 44 return 0; 45 }
G. Monsters and Potions
Unsolved.
H. BerOS File Suggestion
水。
1 #include<bits/stdc++.h> 2 3 using namespace std; 4 5 map<string, int>mp1; 6 map<string, string>mp2; 7 8 int n, q; 9 string s; 10 11 int main() 12 { 13 ios::sync_with_stdio(false); 14 cin.tie(0); 15 cout.tie(0); 16 while(cin >> n) 17 { 18 mp1.clear(); 19 mp2.clear(); 20 for(int i = 1; i <= n; ++i) 21 { 22 cin >> s; 23 int len = s.length(); 24 set<string>st; 25 for(int i = 0; i < len; ++i) 26 { 27 string tmp = ""; 28 for(int j = i; j < len; ++j) 29 { 30 tmp += s[j]; 31 st.insert(tmp); 32 } 33 } 34 for(auto it : st) 35 { 36 mp1[it]++; 37 mp2[it] = s; 38 } 39 } 40 cin >> q; 41 while(q--) 42 { 43 cin >> s; 44 cout << mp1[s] << " "; 45 if(mp1[s]) 46 { 47 cout << mp2[s] << "\n"; 48 } 49 else 50 { 51 cout << "-\n"; 52 } 53 } 54 } 55 return 0; 56 }
I. Privatization of Roads in Berland
Unsolved.
J. Streets and Avenues in Berhattan
Unsolved.
K. Video Posts
水。
1 #include<bits/stdc++.h> 2 3 using namespace std; 4 5 const int maxn = 1e5 + 10; 6 7 int n, k; 8 int arr[maxn]; 9 int sum; 10 11 void solve() 12 { 13 if(sum % k) 14 { 15 puts("No"); 16 return ; 17 } 18 vector<int>vec; 19 int res = 0; 20 int st = 0; 21 for(int i = 1; i <= n; ++i) 22 { 23 res += arr[i]; 24 if(res > sum / k) 25 { 26 puts("No"); 27 return ; 28 } 29 else if(res == sum / k) 30 { 31 vec.push_back(i - st); 32 st = i; 33 res = 0; 34 } 35 } 36 puts("Yes"); 37 for(int i = 0, len = vec.size(); i < len; ++i) 38 { 39 printf("%d%c", vec[i], " \n"[i == len - 1]); 40 } 41 } 42 43 int main() 44 { 45 while(~scanf("%d %d", &n ,&k)) 46 { 47 sum = 0; 48 for(int i = 1; i <= n; ++i) 49 { 50 scanf("%d", arr + i); 51 sum += arr[i]; 52 } 53 solve(); 54 } 55 return 0; 56 }
L. Odd Federalization
Unsolved.
M. Algoland and Berland
Unsolved.