绝对素数.c 674 B

123456789101112131415161718192021222324252627282930313233343536373839404142
  1. #include <stdio.h>
  2. #include <math.h>
  3. int prime(int num) {
  4. int i;
  5. if (num <= 1)
  6. return 0;
  7. if (num == 2)
  8. return 1;
  9. if (num % 2 == 0)
  10. return 0;
  11. for (i = 3; i <= sqrt(num); i += 2) {
  12. if (num % i == 0)
  13. return 0;
  14. }
  15. return 1;
  16. }
  17. int reverse(int num) {
  18. int reversedNum = 0;
  19. while (num > 0) {
  20. reversedNum = reversedNum * 10 + num % 10;
  21. num /= 10;
  22. }
  23. return reversedNum;
  24. }
  25. int main() {
  26. int m, n;
  27. int i;
  28. scanf("%d %d", &m, &n);
  29. for (i = m; i <= n; i++) {
  30. if (prime(i) && prime(reverse(i)))
  31. printf("%d\n", i);
  32. }
  33. return 0;
  34. }