1-9这9个不重复数字,划分成三个3位数 i j k,使得i : j : k=1:2:3

本题主要考察逻辑分析能力和耐心,一般能会粗暴使用低效的枚举法,即3个关于i,j,k的for循环一个个判断。

1)数字不重复,i最小数字是123,k最大数字是987,i*3<=987,即i最大数字329  ,需要循环329-123=206次
2)当i=num, j=2num,k=3num,判断123456789是否都用到了。

void Start () {
        int i, j, k;
        int[] visit = new int[10];
        for (i = 123; i <= 329; i++)
        {
            for (int p = 0; p < visit.Length; p++) visit[p] = 0;
            
            visit[i / 100] = 1;
            int charNum = i / 10 % 10;  //取i的十位字符
            if (charNum!=0&&visit[charNum] == 0)
                visit[charNum] = 1;
            else continue;
            charNum = i % 10;       //取i的个位字符
            if (charNum != 0&&visit[charNum] == 0)
                visit[charNum] = 1;
            else continue;

            j = i * 2;
            charNum = j / 100;   //取j的百位字符
            if (charNum != 0 && visit[charNum] == 0)
                visit[charNum] = 1;
            else continue;
            charNum = j / 10 % 10; //取j的十位字符
            if (charNum != 0 && visit[charNum] == 0)
                visit[charNum] = 1;
            else continue;
            charNum = j % 10;       //取j的个位字符
            if (charNum != 0 && visit[charNum] == 0)
                visit[charNum] = 1;
            else continue;

            k = i * 3;
            charNum = k / 100;   //取k的百位字符
            if (charNum != 0 && visit[charNum] == 0)
                visit[charNum] = 1;
            else continue;
            charNum = k / 10 % 10; //取k的十位字符
            if (charNum != 0 && visit[charNum] == 0)
                visit[charNum] = 1;
            else continue;
            charNum = k % 10;       //取k的个位字符
            if (charNum != 0 && visit[charNum] == 0)
                visit[charNum] = 1;
            else continue;

            Debug.Log(k+"\t"+ j+"\t"+ i);  //代码能够执行到这里说明i : j : k=1:2:3,且123456789都被用到了
        }
### 回答1: 可以使用Java中的Set和Random类来生重复的随机数序列。 具体实现方法如下: 1. 创建一个Set集合,用于存储随机数序列。 2. 使用Random类生随机数,并将其添加到Set集合中,如果Set集合中已经存在该随机数,则重新生随机数。 3. 重复步骤2,直到Set集合中存储的随机数个数达到指定的数量。 4. 将Set集合转换为数组,即可得到不重复的随机数序列。 以下是示例代码: ```java import java.util.HashSet; import java.util.Random; import java.util.Set; public class RandomDemo { public static void main(String[] args) { int n = 16; // 随机数数量 int min = 1; // 随机数最小值 int max = 16; // 随机数最大值 Set<Integer> set = new HashSet<>(); Random random = new Random(); while (set.size() < n) { int num = random.nextInt(max - min + 1) + min; set.add(num); } int[] arr = set.stream().mapToInt(Integer::intValue).toArray(); for (int i : arr) { System.out.print(i + " "); } } } ``` 输出结果类似于:7 15 12 5 4 14 1 11 6 3 16 8 13 2 9 10 ### 回答2: 实现Java 1-16的随机数不重复的方法有很多,下面是一种简单的方法: 1. 首先,创建一个长度为16的整型数组,用于存放取出的随机数,初始化为0。 2. 然后,使用Java的Random类生一个随机数。 3. 判断该随机数是否已存在于数组中,如果不存在,则将该随机数存入数组中,并将数组中对应下标的值设置为该随机数。 4. 如果已存在于数组中,则重新生一个随机数,并重复上述步骤。 5. 重复上述步骤,直到数组中存满16个不重复的随机数。 6. 最后,输出数组中的16个随机数。 示例代码如下: ```java import java.util.Random; public class RandomUniqueNumbers { public static void main(String[] args) { int[] numbers = new int[16]; int count = 0; Random random = new Random(); while (count < 16) { int randomNumber = random.nextInt(16) + 1; boolean isDuplicate = false; for (int i = 0; i < count; i++) { if (numbers[i] == randomNumber) { isDuplicate = true; break; } } if (!isDuplicate) { numbers[count] = randomNumber; count++; } } System.out.println("生的随机数为:"); for (int i = 0; i < 16; i++) { System.out.print(numbers[i] + " "); } } } ``` 运行上述代码,会输出一个不重复的1-16范围内的随机数序列。 ### 回答3: 要实现Java中1到16的随机数不重复的功能,可以使用java.util包中的Random类和一个数组来实现。 首先,创建一个大小为16的整型数组,用来存放1到16这些数字。然后,利用Random类生1到16之间的随机数,并将其与数组中的数字进行交换,以实现乱序排列。最后,根据需要获取的随机数个数,从数组中取出对应个数的数字即可。 具体的步骤如下: 1. 导入java.util包中的Random类。 2. 创建一个大小为16的整型数组,用来存放1到16这些数字。 3. 使用Random类生1到16之间的随机数,将其与数组中当前遍历的位置的数字进行交换,即将生的随机数放入当前位置,并将当前位置之前的数字置为已经生过的数字。 4. 循环执行上述步骤,直到遍历完整个数组。 5. 根据需要获取的随机数个数,从数组中取出对应个数的数字即可。 通过以上步骤,即可实现1到16的随机数不重复的功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值