无意看到某次面试没有通过后,在家苦练基本功后重新写的一串代码。

方法千万种,以下是我印象最深的,回头看还是觉得挺有学习意义的,所以发出来共享学习。

原问题条件不记得太清,大致实现的是:随机生成九宫格图形(手势)密码

 

读题,有几个点需要主要:
1、密码长度可设置

2、手势密码的路径必须可直达

用两种方式实现:

1、canArr 判断前后数值是否可直达

2、getNum 根据前一个数值获取下一个数值

package com.maomao;

import org.testng.annotations.Test;
import java.util.HashMap;
import java.util.Map;

//随机生成九工格图形密码,随机数范围1~9
public class RandomScret {

    //9工格中,1~9可直达的数值,发现规律
    //除了5
    //奇数,1,3,7,9,四个角无法直达
    //偶数,2,4,6,8,对角无法直达,并且对角和5的差值相同
    //    int[] num_1={2,4,5,6,8};
    //    int[] num_2={1,3,4,5,6,7,9};
    //    int[] num_3={2,4,5,6,8};
    //    int[] num_4={1,2,3,5,7,8,9};
    //    int[] num_5={1,2,3,4,6,7,8,9};
    //    int[] num_6={1,2,3,5,7,8,9};
    //    int[] num_7={2,4,5,6,8};
    //    int[] num_8={1,3,4,5,6,7,9};
    //    int[] num_9={2,4,5,6,8};

    //获取1~9的随机整数
    //( n~m随机数公式:(int)(Math.random()*(m-n+1) +n)))
    public static int getRandomNum(){
        int num=(int)(Math.random()*9+1);
        return num;
    }

    //判断是否可以抵达 -----这种方式需要不停试错,花费时间较长
    public Boolean canArr(int preNum,int randomNum){
        //做标记,默认不可以抵达
        boolean flag = false;
        //前后值不能相等
        if (preNum!=randomNum){
            if (preNum==5 ) {
                flag = true;
            }else if (randomNum==5){
                flag = true;
            }else if (preNum%2==0){ //是偶数
                int n=Math.abs(preNum-5);
                int m=Math.abs(randomNum-5);
                if (n!=m){
                    flag=true;
                }
            }else if (preNum%2==1){ //preNum是除了5以外的奇数
                if (randomNum%2==0){
                    flag=true;
                }
            }
        }

        return flag;
    }

    //构造可直达路径 ------这种方式占用内存,花费时间短
    public Map<Integer,int[]> All() {
        Map<Integer, int[]> map = new HashMap<>();
        map.put(1,new int[]{2,4,5,6,8});
        map.put(2,new int[]{1,3,4,5,6,7,9});
        map.put(3,new int[]{2,4,5,6,8});
        map.put(4,new int[]{1,2,3,5,7,8,9});
        map.put(5,new int[]{1,2,3,4,6,7,8,9});
        map.put(6,new int[]{1,2,3,5,7,8,9});
        map.put(7,new int[]{2,4,5,6,8});
        map.put(8,new int[]{1,3,4,5,6,7,9});
        map.put(9,new int[]{2,4,5,6,8});

        return map;
    }
    public int getNum(int preNum){
//        int tag=(int)(Math.random()*10);
        int[] nextArr=All().get(preNum);
        int tag=(int)(Math.random()*10+1);//1~10
        int next=nextArr[tag%nextArr.length];
        return next;
    }

    @Test
    public void test1(){
        RandomScret rs=new RandomScret();

        //设置密码长度length
        int length=6;
        int[] scret=new int[length];

        //指定生成
        int preNum=getRandomNum();
        for (int i=0;i<length;i++){
            scret[i]=rs.getNum(preNum);
            preNum=scret[i];
        }

        for (int num:scret){
            System.out.println(num);
        }
    }

    @Test
    public void test2(){
        RandomScret rs=new RandomScret();

        //设置密码长度length
        int length=6;
        int[] scret=new int[length];

        //随机生成
        int preNum=getRandomNum();
        for (int i=0;i<length;){
            int randomNum=getRandomNum();
            if (rs.canArr(preNum,randomNum)){
                scret[i]=randomNum;
                preNum=scret[i];
                i++;
            }else {
                continue;
            }
        }

        for (int num:scret){
            System.out.println(num);
        }
    }
}

 

内容来源于网络如有侵权请私信删除

文章来源: 博客园

原文链接: https://www.cnblogs.com/fatCat1/p/12877420.html

你还没有登录,请先登录注册
  • 还没有人评论,欢迎说说您的想法!