Advertisement
Not a member of Pastebin yet?
Sign Up,
it unlocks many cool features!
- #include <iostream>
- #include<vector>
- using namespace std;
- int splitArray(vector<int> &v, int subarrays){
- int l = 0, r = 0, res = 0;
- for(int i : v){
- l = max(l, i);
- r += i;
- }
- while(l <= r){
- int mid = l + (r - l) / 2;
- int subarrayReq = 1, subarraySum = 0;
- for(int i = 0; i < (int) v.size(); i++){
- subarraySum += v[i];
- if(subarraySum > mid){
- subarrayReq++;
- subarraySum = v[i];
- }
- }
- if(subarrayReq <= subarrays){
- res = mid;
- r = mid - 1;
- }
- else{
- l = mid + 1;
- }
- }
- return res;
- }
- int main()
- {
- int n;
- cin >> n;
- vector<int> v(n);
- for(int i = 0; i < n; i++){
- cin >> v[i];
- }
- int subarrays;
- cin >> subarrays;
- cout << splitArray(v, subarrays) << '\n';
- return 0;
- }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement