650B - Image Preview - CodeForces Solution


binary search brute force dp two pointers *1900

Please click on ads to support us..

C++ Code:

#include<bits/stdc++.h>

using namespace std;

const int N=1e6+10;

int n,a,b,t;

char s[N],s2[N];

int c[N];

int check(int x){

	for(int i=n-x+1;i<=n;i++){

	    if(i==n-x+1||i==n){

	        if(c[i+x-1]-c[i-1]<=t){

	         //   cout<<i<<endl;

	            return 1;

	        }

	    }

	  else{

	      if(c[i+x-1]-c[i-1]+a*min(n-i,i+x-1-n)<=t){

	          

	         // cout<<i<<endl;

	          return 1;

	      }

	    }

	  }

		

	

	return 0;

}

int main(){

    cin>>n>>a>>b>>t;

   scanf("%s",s2+1);

   for(int i=1;i<=n;i++)s[i]=s2[i];

   for(int i=1;i<=n;i++){

   	s[i+n]=s2[i];

   }

   for(int i=1;i<=n*2;i++){

     // cout<<i<<" "<<s[i]<<endl;

   	  if(s[i]=='w')c[i]=b+a+1;

   	  else c[i]=a+1;

   }

  

   t+=a;

   for(int i=1;i<=n*2;i++){

   	c[i]=c[i-1]+c[i];

  //	cout<<i<<" "<<c[i]<<endl;

   }

 //  n++;

  // check(8);

   

   

  int l=1,r=n;

  n++;

  while(l<=r){

  	int mid=l+r>>1;

  	if(check(mid))l=mid+1;

  	else r=mid-1;

  }

  cout<<r<<endl;

}


Comments

Submit
0 Comments
More Questions

162. Find Peak Element
1529A - Eshag Loves Big Arrays
19. Remove Nth Node From End of List
925. Long Pressed Name
1051. Height Checker
695. Max Area of Island
402. Remove K Digits
97. Interleaving String
543. Diameter of Binary Tree
124. Binary Tree Maximum Path Sum
1465. Maximum Area of a Piece of Cake After Horizontal and Vertical Cuts
501A - Contest
160A- Twins
752. Open the Lock
1535A - Fair Playoff
1538F - Interesting Function
1920. Build Array from Permutation
494. Target Sum
797. All Paths From Source to Target
1547B - Alphabetical Strings
1550A - Find The Array
118B - Present from Lena
27A - Next Test
785. Is Graph Bipartite
90. Subsets II
1560A - Dislike of Threes
36. Valid Sudoku
557. Reverse Words in a String III
566. Reshape the Matrix
167. Two Sum II - Input array is sorted