juten10x

Info - Blog - Gallerypile_of_codes (study/3) > isPrime

isPrime

C++

#include <iostream>

/*
  素数かどうかを判定します。
  素数でない場合には、何で割ることができるかを式で示します。
*/

long long isPrime(long long x) {
  if (x == 1) return 0;
  for (long long i = 2; i*i <= x; i++) {
    if (x%i == 0) return i;
  }
  return 1;
}

int main() {
  long long N;
  std::cin >> N;

  long long t = isPrime(N);

  if (t == 1) {
    std::cout << N << " は素数です\n";
  }
  else {
    std::cout << N << " は素数ではありません\n";
    if (N != 1) {
      std::cout << N << " ÷ " << t << " = " << N/t << '\n';
    }
  }

  return 0;
}

JavaScript

function isPrime(x) {
  if (N == 1) return 0;

  for (let i = 2; i*i <= N; i++) {
    if (N%i == 0) return i;
  }

  return 1;
}

let N = prompt("10^8 以下の数字を入力してください");
let t = isPrime(N);

if (t == 1) {
  document.write(N + " は素数です")
}
else {
  document.write(N + " は素数ではありません" + "<br>");
  if (t != 1) {
    document.write(N + " ÷ " + t + " = " + N/t + "<br>");
  }
}