Passeio da Primavera (Pensando + Discussão)

https://ac.nowcoder.com/acm/contest/11163/E


Solução oficial:

As cinco situações a seguir levam as menores

1. Todas as pessoas remam em um barco duplo

(n + 1) / 2 ∗ a

2. Todos podem remar um barco duplo, mas uma pessoa pode remar um barco duplo sozinha.
Retire um irmão em um barco para duas pessoas e três pessoas dirigem um barco para três pessoas.

(n − 2) / 2 ∗ a + b

3. Todos remavam em um barco de três pessoas

(n + 2) / 3 ∗ b

4. Todos remavam em um barco para três pessoas, mas havia duas pessoas que remavam em um barco para três pessoas, e os dois irmãos estavam dispostos em um barco para duas pessoas em um espaço.

n / 3 ∗ b + a

5. Todos estão remando um barco de três pessoas e uma pessoa está remando um barco de três pessoas.
Retire um irmão que é um barco de três pessoas, então há quatro pessoas e dois barcos de duas pessoas.

(n − 2) / 3 ∗ b + a + a


Durante o jogo, não pensei em 5 dados para tal situação .. Na verdade, existem

#include<iostream>
#include<vector>
#include<queue>
#include<cstring>
#include<cmath>
#include<map>
#include<set>
#include<cstdio>
#include<algorithm>
#define debug(a) cout<<#a<<"="<<a<<endl;
using namespace std;
const int maxn=1e5;
typedef long long LL;
inline LL read(){LL x=0,f=1;char ch=getchar();	while (!isdigit(ch)){if (ch=='-') f=-1;ch=getchar();}while (isdigit(ch)){x=x*10+ch-48;ch=getchar();}
return x*f;}
int main(void)
{
  cin.tie(0);std::ios::sync_with_stdio(false);
  LL T;cin>>T;
  while(T--){
    LL n,a,b;cin>>n>>a>>b;
    LL num1=(n+1)/2*a;
    LL num2=(n-2)/2*a+b;
    LL num3=(n+2)/3*b;
    LL num4=n/3*b+a;
    LL num5=(n-2)/3*b+a+a;
    cout<<min(num1,min(num2,min(num3,min(num4,num5))))<<"\n";
  }
return 0;
}

 

Acho que você gosta

Origin blog.csdn.net/zstuyyyyccccbbbb/article/details/115037518
Recomendado
Clasificación