結果

問題 No.505 カードの数式2
ユーザー vjudge1
提出日時 2025-06-24 21:27:12
言語 C++17
(gcc 13.3.0 + boost 1.87.0)
結果
WA  
実行時間 -
コード長 754 bytes
コンパイル時間 2,035 ms
コンパイル使用メモリ 193,580 KB
実行使用メモリ 7,844 KB
最終ジャッジ日時 2025-06-24 21:27:28
合計ジャッジ時間 15,582 ms
ジャッジサーバーID
(参考情報)
judge4 / judge1
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 21 WA * 8
権限があれば一括ダウンロードができます
コンパイルメッセージ
main.cpp: In function ‘int main()’:
main.cpp:44:14: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
   44 |         scanf("%lld",&n);
      |         ~~~~~^~~~~~~~~~~
main.cpp:45:35: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
   45 |         for(int i=1;i<=n;i++)scanf("%lld",&a[i]);
      |                              ~~~~~^~~~~~~~~~~~~~

ソースコード

diff #

#include<bits/stdc++.h>
#define int long long
#define inf 0x3f3f3f3f3f3f3f3f
using namespace std;
int n,a[22],ans=-inf,now;
char symb[22];
void dfs(int k){
	if(k>n){
		now=a[1];
		for(int i=2;i<=n;i++){
			if(symb[i]=='+')now+=a[i];
			else if(symb[i]=='-')now-=a[i];
			else if(symb[i]=='*')now*=a[i];
			else now/=a[i];
		}
		ans=max(ans,now);
		return;
	}
	if(a[k]>0){
		symb[k]='+';
		dfs(k+1);
		symb[k]='*';
		dfs(k+1);
		symb[k]='/';
		dfs(k+1);
	}
	else if(a[k]<0){
		symb[k]='-';
		dfs(k+1);
		symb[k]='*';
		dfs(k+1);
		symb[k]='/';
		dfs(k+1);
	}
	else{
		symb[k]='+';
		dfs(k+1);
		symb[k]='*';
		dfs(k+1);
	}
	return;
}
signed main(){
	scanf("%lld",&n);
	for(int i=1;i<=n;i++)scanf("%lld",&a[i]);
	dfs(2);
	printf("%lld\n",ans);
	return 0;
}
0