随笔:手机尾号问题

30年的改革开放,给中国带来了翻天覆地的变化。2011全年中国手机产量约为11.72亿部。手机已经成为百姓的基本日用品!

    给手机选个好听又好记的号码可能是许多人的心愿。但号源有限,只能辅以有偿选号的方法了。

    这个程序的目的就是:根据给定的手机尾号(4位),按照一定的规则来打分。其规则如下:

   1. 如果出现连号,不管升序还是降序,都加5分。例如:5678,4321都满足加分标准。

   2. 前三个数字相同,或后三个数字相同,都加3分。例如:4888,6665,7777都满足加分的标准。注意:7777因为满足这条标准两次,所以这条规则给它加了6分。

   3. 符合AABB或者ABAB模式的加1分。例如:2255,3939,7777都符合这个模式,所以都被加分。注意:7777因为满足这条标准两次,所以这条标准给它加了2分。

   4. 含有:6,8,9中任何一个数字,每出现一次加1分。例如4326,6875,9918都符合加分标准。其中,6875被加2分;9918被加3分。

    尾号最终得分就是每条标准的加分总和!

    要求程序从标准输入接收数据,在标准输出上输出结果。

    输入格式为:第一行是一个整数n(<100),表示下边有多少输入行,接下来是n行4位一组的数据,就是等待计算加分的手机尾号。

    输出格式为:n行整数。

    例如,输入:

14

3045

0211

2345

6543

7777

8888

7878

7788

6688

2424

2244

9918

6789

8866

    则输出:

0

0

5

6

8

12

3

3

5

1

1

3

8

5


java代码如下:

public class PhoneNumberProcess
{
	
	public static void main(String[] args)
	{
		//只写了单个数据的测试,没有按题目要求,也没有做什么异常处理
		int score=processNumber("8866");
		System.out.println(score);
	}
	public static int processNumber(String number){
		
		
		int [] numberArray=new int[10];
		int index=0;
		for(int i=0;i<number.length();i++){
			index=Integer.parseInt(number.substring(i, i+1));
			numberArray[index]++;
		}
		
		return firstProcess(numberArray)+
				secondProcess(numberArray)+
				thirdProcess(number)+
				fouthProcess(numberArray);
	}
	public static int firstProcess(int [] numberArray){

		for(int i=0;i<numberArray.length-3;i++){
			if(numberArray[i]!=0&&numberArray[i+1]!=0&&numberArray[i+2]!=0&&numberArray[i+3]!=0)return 5;
		}
		return 0;
	}
	public static int secondProcess(int [] numberArray){
		
		for(int i=0;i<numberArray.length;i++){
			if(numberArray[i]==3){
				return 3;
			}else if(numberArray[i]==4){
				return 6;
			}else{
				continue;
			}
		}
		return 0;
	}
	public static int thirdProcess(String number){
		
		int score=0;
		
		String forSubStr=number.substring(0, 2);
		String letSubStr=number.substring(2,4);
		if(forSubStr.equals(letSubStr))score+=1;
		
		char[] numbers=number.toCharArray();
		if(numbers[0]==numbers[1]&&numbers[2]==numbers[3])score+=1;
		
		return score;
	}
	public static int fouthProcess(int [] numberArray){
		
		return numberArray[6]+numberArray[8]+numberArray[9];
	}

}


你可能感兴趣的:(随笔:手机尾号问题)