Robot saltando problema de desbordamiento de dos puntos de atención

Dos puntos del problema del salto del robot.

El mínimo es 0 y el máximo es el valor máximo de la matriz H [], y luego la dicotomía

! ! ! ! Tenga en cuenta que en la matriz get, si la energía acumulada es mayor que el valor máximo, se devuelve 1; de lo contrario, la energía se acumulará para desbordar, lo que generará un error en el resultado.

#include<iostream>
using namespace std;


int h[100005]; 

int n;
int maxx=0;
bool get(int xx)
{
    
    
	long long ene=xx;
	
	for(int i=1;i<=n;i++)
	{
    
    
		ene=(ene+ene-h[i]);
//		cout<<ene<<" "<<i<<endl;
		if(ene<0)
		{
    
    
//			cout<<endl<<"***"<<i<<"****";
			return 0;	
		}
		
		if(ene>maxx)       //!!!!!!!!
			return 1;
		
	}
	
	return 1;	
}

int main()
{
    
    
	
	
	
	cin>>n;
	
	
	for(int i=1;i<=n;i++)
	{
    
    
		scanf("%d",&h[i]);
		maxx=max(maxx,h[i]);
		
	}
	
	int l=0;
	int r=maxx+1;
	
	int mid;
	
//	cout<<get(23);
	
	while(l<r)
	{
    
    
		mid=(l+r)/2;
		
		
		if(get(mid))
		{
    
    
			r=mid;
		}else {
    
    
			l=mid+1;
		}
	}
	
	cout<<l;
	
	
	
	return 0;
}

Supongo que te gusta

Origin blog.csdn.net/weixin_45448563/article/details/113828059
Recomendado
Clasificación