結果

問題 No.3023 素数判定するだけ
ユーザー maimai
提出日時 2017-03-30 09:31:23
言語 C#(csc)
(csc 3.9.0)
結果
TLE  
実行時間 -
コード長 953 bytes
コンパイル時間 2,796 ms
コンパイル使用メモリ 104,912 KB
実行使用メモリ 28,588 KB
最終ジャッジ日時 2023-09-21 03:04:55
合計ジャッジ時間 8,378 ms
ジャッジサーバーID
(参考情報)
judge13 / judge11
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 TLE -
testcase_01 -- -
testcase_02 -- -
testcase_03 -- -
testcase_04 -- -
testcase_05 -- -
testcase_06 -- -
testcase_07 -- -
testcase_08 -- -
testcase_09 -- -
testcase_10 -- -
testcase_11 -- -
testcase_12 -- -
testcase_13 -- -
testcase_14 -- -
testcase_15 -- -
testcase_16 -- -
testcase_17 -- -
testcase_18 -- -
testcase_19 -- -
testcase_20 -- -
testcase_21 -- -
testcase_22 -- -
testcase_23 -- -
testcase_24 -- -
権限があれば一括ダウンロードができます
コンパイルメッセージ
Microsoft (R) Visual C# Compiler version 3.9.0-6.21124.20 (db94f4cc)
Copyright (C) Microsoft Corporation. All rights reserved.

ソースコード

diff #

using System;
public class Program
{
  
  const int one   =('C'^'B');
  const int zero  =('A'^'A');
  const int twelve=('M'^'A');
  
static int add(int a,int b){
  int c;
  while(zero<b){
    c = a&b;
    a = a^b;
    b = c<<one;
  }
  return a;
}

static int negative(int a){
  return add(~a,one);
}

static int mul(int a,int b){
  int c=b;
  int r=zero;
  while(zero<c){
    c=add(c,negative(one));
    r=add(r,a);
  }
  return r;
}
static int mod(int a,int d){
  int q=zero,r=zero,i;
  for (i=twelve;zero<=i;i=add(i,negative(one))){
    r <<= one;
    r |= (a>>i)&one;
    if (r >= d){
      r = add(r,negative(d));
      q|=one<<i;
    }
  }
  return r;
}

  
  static void Main()
  {
    string s = Console.ReadLine();
    int x = int.Parse(s);
    int i;
    if (x==one){Console.WriteLine("NO");return ;}
    for (i=add(one,one);i<x;i=add(i,one)){if (mod(x,i)==zero){Console.WriteLine("NO");return ;}}
    Console.WriteLine("YES");return ;
  }
}

0