Advertisement
Rofyda_Elghadban1

Untitled

Sep 18th, 2023
856
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 2.77 KB | None | 0 0
  1.  #include <bits/stdc++.h>
  2.  
  3.  #define ll long long
  4.  #define ull unsigned long long
  5.  #define pi 3.141592654
  6.  #define NUM 1e18
  7.  #define Mod  1'000'000'007
  8.  #define fixed(n) fixed<<setprecision(n)
  9.  #define cin(v) for(auto &i:v) cin >> i ;
  10.  #define cout(v) for(auto &i:v) cout << i  <<" ";
  11.  #define vowel(x) (x=='e'||x=='a'||x=='i'||x=='o'||x=='u')
  12.  #define small(x) (x>=97&&x<=122)
  13.  #define capital(x) (x>=65&&x<=90)
  14.  #define Tolower(s) transform(s.begin(),s.end(),s.begin(),::tolower);
  15.  #define Toupper(s) transform(s.begin(),s.end(),s.begin(),::toupper);
  16.  #define all(v) ((v).begin()), ((v).end())
  17.  #define allr(v) ((v).rbegin()), ((v).rend())
  18.  #define updmax(a,b) a=max(a,b)
  19.  #define updmin(a,b) a=min(a,b)
  20.  #define ceil(a,b) ((a/b)+(a%b?1:0))
  21.  /* asc -> 1 2 3 ,des -> 3 2 1 */
  22.  
  23.  /***********************************************************************************/
  24.  
  25.  using namespace std;
  26.  
  27.  void Rofyda_Elghadban(){
  28.   #ifndef ONLINE_JUDGE  
  29.     freopen("input.txt", "r", stdin), freopen("output.txt", "w", stdout);
  30.    #endif
  31.     ios_base::sync_with_stdio(false), cin.tie(nullptr), cout.tie(nullptr);
  32.  }
  33.  
  34.  
  35.  void solve(){
  36.   int n,k;
  37.   cin>>n>>k;
  38.   vector<int>v(n+1),t(n+1),v2;
  39.   for(int i=1;i<n+1;i++){
  40.     cin>>v[i];
  41.   }
  42.   for(int i=1;i<n+1;i++){
  43.     cin>>t[i];
  44.   }
  45.   for(int i=0;i<n+1;i++){
  46.     if(t[i]==1){
  47.       v2.push_back(v[i]);
  48.     }else if(t[i]==0||i==0){
  49.       v2.push_back(0);
  50.     }
  51.   }
  52.   // cout(v2);
  53.   // cout<<"\n";
  54.   int prefix1[100001]{},prefix2[100001]{},pre=0;
  55.   for(int i=1;i<n+1;i++){
  56.     prefix1[i]=v[i]+prefix1[i-1];
  57.   }
  58.   for(int i=1;i<n+1;i++){
  59.     // if(v2[i]!=0){
  60.     //   prefix2[i]=v2[i]+pre;
  61.     //   pre=prefix2[i];
  62.     // }else if(v2[i]==0){
  63.     //   prefix2[i]=0;
  64.     prefix2[i]=v2[i]+prefix2[i-1];
  65.     // }
  66.   }
  67.   // for(int i=1;i<n+1;i++){
  68.   //   cout<<prefix1[i]<<" ";
  69.   // }  
  70.   // cout<<"\n";
  71.   for(int i=1;i<n+1;i++){
  72.     cout<<prefix2[i]<<" ";
  73.   }  
  74.   cout<<"\n";
  75.   int l=1,r=l+k-1,maxi=INT_MIN,idx1=0,idx2=0,s1=0,s=0,s2=0;
  76.   for(int i=1;i<n+1;i++){
  77.     s1=prefix2[l-1]-prefix2[0];
  78.     s=prefix1[r]-prefix1[l-1];
  79.     s2=prefix2[n]-prefix2[r-1];
  80.     // cout<<s1<<" "<<s<<" "<<s2<<"\n";
  81.      cout<<s1+s+s2<<"\n"<<"*********************"<<"\n";
  82.     //if(maxi<=(s1+s+s2)){
  83.     maxi=max(maxi,(s1+s+s2));
  84.     //}
  85.     if(r<=n){
  86.       l++;
  87.       r++;
  88.       s1=0;
  89.       s=0;
  90.       s2=0;
  91.     }
  92.   }
  93.   // cout<<"\n";
  94.   // for(int i=1;i<idx1;i++){
  95.   //   if(t[i]==1){
  96.   //     maxi+=v[i];
  97.   //   }
  98.   // }
  99.   // for(int i=idx2+1;i<n+1;i++){
  100.   //   if(t[i]==1){
  101.   //     maxi+=v[i];
  102.   //   }
  103.   // }
  104.  
  105.   cout<<maxi<<"\n";
  106.   // cout<<l<<" "<<r;
  107.  }
  108.  
  109.  
  110.  int main(){
  111.  Rofyda_Elghadban();
  112.  //freopen("input.txt","r",stdin);
  113.  //freopen("output.txt","r",stdout);
  114.   solve();
  115.  
  116.  
  117.  return 0;
  118. }
  119.  
  120.  
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement