第三次作业

题目一:

1、  问题一:

 public String getPhoneNumber(String strPhoneNum)

 {

        if((strPhoneNum==null) || "".equals(strPhoneNum))

 {
            return  "";

 }

  问题二:

    区号-电话号码—分机号输入应为数字且长度为11位

  问题三:

    区号-电话号码—分机号的格式为4位区号,8位直播号码,3位分机号

2.原因为:

  原因一:问题一中输入的电话为空值,但是却返回""

  原因二:系统需求中代码不够完善

3.修改后代码为:

   public String getPhoneNumber(String strPhoneNum)

  {
        if((strPhoneNum==null) || "".equals(strPhoneNum)){

    System.out.println("输入的号码不能为空!");

        return false;        

      }     

 

  if (strPhoneNum.length() != 11) {
     throw new Exception("号码必须长11位"); 
    }

  for (int i = 2; i < strPhoneNum.length(); i++) {
     char p = strPhoneNum.charAt(i); 
     if (p < '0' || p > '9') {
      throw new Exception("号码必须数字组成!");
     }

    }

     String format="((\d{11})|^((\d{7,8})|(\d{4}|\d{3})-(\d{7,8})|(\d{4}|\d{3})-(\d{7,8})-(\d{4}|\d{3}|\d{2}|\d{1})|(\d{7,8})-(\d{4}|\d{3}|\d{2}|\d{1}))$)";

  if(strPhoneNum.matches(format))

        {

      return true;

        }

      else{

      return false;

      System.out.println("输入的电号码格式不合格!");

        }

    }

   String[] arrPhone=strPhoneNum.split("-");
        return arrPhone[1];
      }

split("-") 方法得到的数字结果为

0591

83279988

002

返还arrPhone[1]则表示返还为第二个数组 所以结果得到83279988

 

题目二:

一、代码:

 

package cn.VV.demo;

public class VV {
 /**
  * @param args
  * 插入排序
  */
 public int[] V(int[] arr)  // 定义数组arr;

 {     
    for (int i = 1; i < arr.length; i++)
      for (int j = i; j > 0; j--)

 {
     if (arr[j] > arr[j - 1])

    {
       int temp = arr[j - 1];//第一个起,依次和后边的比较,如果大于后边的往后移动
       arr[j - 1] = arr[j];
       arr[j] = temp;
     }  

      else break;

     }
        return arr; //返还arr
 }
 }

二:设计思路

有一组数据,从左到右一个个扫描,如果,前一个数字大于后一个数字,则前一个数字往后移一位,以此类推。

三:可能出错的情况

1、数组没有数字

2、数组数字全部相同(如:2,2,2,2,2)

3、数组有数字为负数(如:4,-5,6,7)

4、数组数字0开头(如:0,2,3,4)

5、数组各个数字由一个数字组成且有负数(如:22,2.222,-2222)

posted on 2016-05-24 22:07  乐见访客  阅读(150)  评论(0编辑  收藏  举报