結果
| 問題 |
No.7 プライムナンバーゲーム
|
| コンテスト | |
| ユーザー |
notetonous
|
| 提出日時 | 2016-04-29 02:10:03 |
| 言語 | C90 (gcc 12.3.0) |
| 結果 |
AC
|
| 実行時間 | 18 ms / 5,000 ms |
| コード長 | 661 bytes |
| コンパイル時間 | 193 ms |
| コンパイル使用メモリ | 21,504 KB |
| 実行使用メモリ | 5,248 KB |
| 最終ジャッジ日時 | 2024-10-01 15:43:03 |
| 合計ジャッジ時間 | 783 ms |
|
ジャッジサーバーID (参考情報) |
judge1 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 17 |
コンパイルメッセージ
main.c: In function ‘main’:
main.c:15:3: warning: ignoring return value of ‘scanf’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
15 | scanf("%d",&n);
| ^~~~~~~~~~~~~~
ソースコード
#include <stdio.h>
int prime[10001];
int p[5000];
int dp[10001];
int is_prime(int x){
int i;
for(i=2;i*i<=x;i++){
if(x%i==0)return 0;
}
return 1;;
}
int main(){
int n;
int i,j,pcount=0;
scanf("%d",&n);
for(i=2;i<=n;i++){
if(is_prime(i)) {
prime[i]=1;
p[pcount]=i;
pcount++;
}
}
//for(i=0;i<pcount;i++)printf("%d ",p[i]);
dp[0]=1;
dp[1]=1;
for(i=2;i<=n;i++){
j=0;
while(p[j]<=i && j < pcount){
if(dp[i-p[j]]==0){dp[i]=1;
//printf("%d %d\n",i,p[j]);
}
j++;
}
}
// for(i=0;i<=n;i++)printf("%d ",dp[i]);
if(dp[n]==1)printf("Win\n");
else printf("Lose\n");
return 0;
}
notetonous