神奇数

原创 2017年05月20日 14:54:27

给出一个区间[a, b],计算区间内“神奇数”的个数。
神奇数的定义:存在不同位置的两个数位,组成一个两位数(且不含前导0),且这个两位数为质数。
比如:153,可以使用数字3和数字1组成13,13是质数,满足神奇数。同样153可以找到31和53也为质数,只要找到一个质数即满足神奇数。
输入描述:
输入为两个整数a和b,代表[a, b]区间 (1 ≤ a ≤ b ≤ 10000)。

输出描述:
输出为一个整数,表示区间内满足条件的整数个数

输入例子:
11 20

输出例子:
6


AC代码:

import java.util.Arrays;
import java.util.Scanner;

public class Main {

    public static boolean IsPrime(int a){
        boolean flag = true;
        if ( a <= 1){
            flag = false;
        }else if(a == 2){
            flag = true;
        }else{
            for (int i = 2 ; i < a ; i++){
                if ( a % i == 0){
                    flag = false;
                    break;
                }
            }
        }
        return flag;
    }

    public static boolean check(int a){
        int[] A = new int[5];
        Arrays.fill(A, 0);
        int cnt = 0;
        while(a != 0){
            A[cnt++] = a % 10;
            a /= 10;
        }
        /*for ( int i = 0 ; i < cnt ; i++){
            System.out.print(A[i]+" ");
        }*/
        //System.out.println();
        for (int i = 0 ; i < cnt ; i++){
            for ( int j = 0 ; j < cnt && j != i ; j++){
                int tmp1 = A[i]*10 + A[j];
                int tmp2 = A[j]*10 + A[i];
            //  System.out.println(tmp1+"    "+tmp2);
                if (IsPrime(tmp1) && tmp1 > 10){
                //  System.out.println(tmp1+"是神奇数");
                    return true;
                }
                if (IsPrime(tmp2) && tmp2 > 10){
                //  System.out.println(tmp2+"是神奇数");
                    return true;
                }
            }
        }
        return false;
    }

    public static void main(String[] args) {
        // TODO Auto-generated method stub
        Scanner in = new Scanner(System.in);
        int start = in.nextInt();
        int end = in.nextInt();
        int cnt = 0;
        for ( int i = start ; i <= end ; i++){
            if (check(i)){
                cnt++;
            }
        }
        System.out.println(cnt);

        in.close();
    }

}
版权声明:本文为博主原创文章,若需转载,请注明http://blog.csdn.net/qq_30091945

相关文章推荐

给出一个区间[a, b],计算区间内“神奇数”的个数。

题目:给出一个区间[a, b],计算区间内“神奇数”的个数。神奇数的定义:存在不同位置的两个数位,组成一个两位数(且不含前导0),且这个两位数为质数。 例子:153,可以使用数字3和数字1组成13,...

神奇数

时间限制:1秒 空间限制:32768K 给出一个区间[a, b],计算区间内“神奇数”的个数。 神奇数的定义:存在不同位置的两个数位,组成一个两位数(且不含前导0),且这个两位数为质...

html:select 标签 form 提交,action取不到值

html:select 标签 form 提交,action取不到值

Android Hierarchy Viewer

Android的SDK工具包中,有很多十分有用的工具,可以帮助程序员开发和测试Android应用程序,大大提高其工作效率。其中的一款叫Hierachy Viewer的可视化调试工具,可以很方便地帮助开...

浙工大ACM神奇的fans数

  • 2011年07月30日 15:40
  • 810B
  • 下载

上帝的杰作系列之:神奇的数

领受、体验数学之美,尤其是数字的美妙,是神赐予人的智慧能力之一。每一位上帝所拣选的子民都是神所喜爱的,正如每一个数都是上帝所宠爱的杰作。 这一次,让我们体验数9801的奇妙。 1. 祂是最...
  • Suprman
  • Suprman
  • 2015年10月03日 08:33
  • 890

【01背包 && 完全背包】高数Umaru系列(9)——哈士奇 && 小P的故事——神奇的Dota

高数Umaru系列(9)——哈士奇 Time Limit: 1000MS Memory Limit: 65536KB Problem Description由于高数巨养的喵星人太傲娇了,要天天吃新...

算法篇:神奇的卡塔兰数Catalan

这段时间复习数据结构,想起来这神奇的卡塔兰数1.百科简介卡塔兰数的来历:卡特兰数又称卡塔兰数,是组合数学中一个常出现在各种计数问题中出现的数列。由以比利时的数学家欧仁·查理·卡塔兰 (1814–189...

给定N个节点求组成二叉搜索树个数——从一道算法题探讨神奇的Catalan数

引Catalan数,中文卡特兰数又称卡塔兰数,是组合数学中一个常出现在各种计数问题中的数列。一旦入坑,你会发现这个数列相当有意思,能够应用于很多看起来特别复杂的计算场景,当然,并能将之迎刃而解。 ...

神奇的匹配 正则表达式求精之旅

  • 2016年11月01日 17:04
  • 57.44MB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:神奇数
举报原因:
原因补充:

(最多只允许输入30个字)