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;
}