IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 游戏开发 -> java 二维数组实操 -> 正文阅读

[游戏开发]java 二维数组实操

java 二维数组实操

一、灵感来源

这个文章主要是在看了一个十分厉害的大佬的有关双色球的一篇文章之后,有感而发,写出的一个小小的代码。

这个代码主要是针对双色球的随机生成,统计数字出现频率,并整合出一个双色球号码,让随机生成的双色球数字与这个号码的数字的重合率越低越好。

PS:我这里指的双色球是1~32里面选5个,1~16里面选两个。(别问为啥)

二、代码

2.1 双色球生成代码(没有抄)

import java.util.*;
 
public class lotterySimulator
{
   public static int[][] generator(int a, int b)
   {
      int[][] arr = new int[a][b];
      Random random = new Random();
      int c = 0;
      for(int i = 0 ; i < arr.length ; i++)
      {
         for(int j = 0; j < arr[i].length ; j++)
         {           
            while(true)
            {
               c = j == 5 || j == 6 ? random.nextInt(15)+1 : random.nextInt(31)+1;
               if(!contains(c,arr[i]))
               {
                  break;
               }
            } 
            arr[i][j] = c;       
         }
      }
      return arr;
   }
   public static boolean contains(int a, int[] sss)
   {
      boolean result = false;
      for(int er : sss)
      {
         result = er == a ? true : false;
         if(result == true)
         {
            break;
         }
      }
      return result;
   }
   public static void main(String[] args)
   {
      int[][] arra = generator(10,7);
      for(int[] a : arra)
      {
         for(int b : a)
         {
            System.out.print(b+",");
         }
         System.out.println("");
      }
   }
}

2.2 选择排序

毕竟最后做出来的那个号码还是需要验证一下,所以需要一个选择排序来整理一下自动生成的号码,乱糟糟的毕竟不容易检查。

注:这里的代码不是常规的选择排序,请不要直接拿去用,会出问题。

private static int[] selectionSort(int[] arr)
   {
      for (int i = 0; i <arr.length - 3; i++) 
      {
          int index = i;
          for (int j = i + 1; j<arr.length-2; j++) 
          {
              if (arr[j] < arr[index]) 
              {
                  index = j;
              }
          }
          int tmp = arr[index];
          arr[index] = arr[i];
          arr[i] = tmp;
      }
      if(arr[arr.length-2]>arr[arr.length-1])
      {
         int temp = 0;
         temp = arr[arr.length-1];
         arr[arr.length-1] = arr[arr.length-2];
         arr[arr.length-2] = temp;
      }
      return arr;
   }

这里因为最后两个数只需要if比较就好了,不用再多加一个for-for嵌套来遍历。要注意的是第一个for循环的循环次数需要减少,内外for的次数都需要减少2。

PS:这是正常的选择排序

2.3 遍历判断

因为最后需要的是重合率最低的一个号码,所以我们需要将自动生成的二维数组的每个数据进行统计,然后根据出现的次数,选择组成号码的数字。(这个不一定是最好的方法,但一定是在你不想思考的时候可以用的最简单的。

统计的方法,就是用两个二维数组(因为有1~32 和1~16的),这个二维数组是【2】【32】和【2】【16】。就是一个一维数组用来装1~32和1~16这些数字,一个用来装他们出现的次数。

for(int i = 0; i < store32[0].length; i++)
      {
         store32[0][i] = i+1;
      }
      for(int i = 0; i < store16[0].length; i++)
      {
         store16[0][i] = i+1;
      }
      for(int i = 0; i < arra.length; i++)
      {
         for(int j = 0; j < 5; j++)
         {
            for(int k = 0; k < store32[0].length; k++)
            {
               if(arra[i][j] == store32[0][k])
               {
                  store32[1][k] += 1;
               }
            }
         }
      }
      for(int i = 0; i < arra.length; i++)
      {
         for(int j = 5; j < 7; j++)
         {
            for(int k = 0; k < store16[0].length; k++)
            {
               if(arra[i][j] == store16[0][k])
               {
                  store16[1][k] += 1;
               }
            }
         }
      }

?格式有亿点怪,不过不要紧。这里必须用三重for嵌套,因为它是在同时对于三个数据进行遍历。一个是arra这个二维数组所含有的所有一维数组,一个是arra里面的一维数组里面的数据,一个是装了1~32和1~16的数组的数据。一定要用三重,不然会出问题。理论上说,这段代码是可以缩短的,但是我懒,简化的事情就交给你们了。

2.4 筛选最少出现数字

这个筛选的方法有很多,比如说借用选择排序利用索引的方法,选最小然后判断。。。。。。

方法很多,这里我就说一下我的方法。

我的方法主要是while-for嵌套。利用while可以不限制循环次数的特点,配合for的索引,从0开始,将出现次数为0的数字写进一个一维数组,然后+=1,不断遍历。最后for和while都来一个break,就可以了。

while(true)
      {
         for(int i = 0; i < store32[0].length; i++)
         {
            if(store32[1][i] == a)
            {
               output[b] = store32[0][i];
               b += 1;
            }
            if(b == 5)
         {
            break;  
         }
         }
         a += 1;
         if(b == 5)
         {
            break;  
         }
      }
      a = 0;
      b = 5;
      while(true)
      {
         for(int i = 0; i < store16[0].length; i++)
         {
            if(store16[1][i] == a && !contains(store16[0][i],output))
            {
               output[b] = store16[0][i];
               b += 1;
            }
            if(b == 7)
            {
               break;  
            }
         }
         a += 1;
         if(b == 7)
         {
            break;  
         }
      }

三、总代码?

import java.util.*;

public class lotterySimulator
{
   public static int[][] generator(int a, int b)
   {
      int[][] arr = new int[a][b];
      Random random = new Random();
      int c = 0;
      for(int i = 0 ; i < arr.length ; i++)
      {
         for(int j = 0; j < arr[i].length ; j++)
         {           
            while(true)
            {
               c = j == 5 || j == 6 ? random.nextInt(15)+1 : random.nextInt(31)+1;
               if(!contains(c,arr[i]))
               {
                  break;
               }
            } 
            arr[i][j] = c;       
         }
      }
      return arr;
   }
   public static boolean contains(int a, int[] sss)
   {
      boolean result = false;
      for(int er : sss)
      {
         result = er == a ? true : false;
         if(result == true)
         {
            break;
         }
      }
      return result;
   }
   public static void main(String[] args)
   {
      int[][] arra = generator(10,7);
      int[][] store32 = new int[2][32];
      int[][] store16 = new int[2][16];
      int[] output = new int[7];     
      for(int i = 0; i < arra.length; i++)
      {
         selectionSort(arra[i]);
      }
      for(int[] a : arra)
      {
         for(int b : a)
         {
            System.out.print(b+ (b == a[a.length-1] ? "\n" : ","));
         }
      }
      for(int i = 0; i < store32[0].length; i++)
      {
         store32[0][i] = i+1;
      }
      for(int i = 0; i < store16[0].length; i++)
      {
         store16[0][i] = i+1;
      }
      for(int i = 0; i < arra.length; i++)
      {
         for(int j = 0; j < 5; j++)
         {
            for(int k = 0; k < store32[0].length; k++)
            {
               if(arra[i][j] == store32[0][k])
               {
                  store32[1][k] += 1;
               }
            }
         }
      }
      for(int i = 0; i < arra.length; i++)
      {
         for(int j = 5; j < 7; j++)
         {
            for(int k = 0; k < store16[0].length; k++)
            {
               if(arra[i][j] == store16[0][k])
               {
                  store16[1][k] += 1;
               }
            }
         }
      }
      int a = 0;
      int b = 0;
      while(true)
      {
         for(int i = 0; i < store32[0].length; i++)
         {
            if(store32[1][i] == a)
            {
               output[b] = store32[0][i];
               b += 1;
            }
            if(b == 5)
         {
            break;  
         }
         }
         a += 1;
         if(b == 5)
         {
            break;  
         }
      }
      a = 0;
      b = 5;
      while(true)
      {
         for(int i = 0; i < store16[0].length; i++)
         {
            if(store16[1][i] == a && !contains(store16[0][i],output))
            {
               output[b] = store16[0][i];
               b += 1;
            }
            if(b == 7)
            {
               break;  
            }
         }
         a += 1;
         if(b == 7)
         {
            break;  
         }
      }
  
      for(int x : output)
      {
         System.out.print(x == output[output.length-1] ? x : x + ",");
      } 
   }
   private static int[] selectionSort(int[] arr)
   {
      for (int i = 0; i <arr.length - 3; i++) 
      {
          int index = i;
          for (int j = i + 1; j<arr.length-2; j++) 
          {
              if (arr[j] < arr[index]) 
              {
                  index = j;
              }
          }
          int tmp = arr[index];
          arr[index] = arr[i];
          arr[i] = tmp;
      }
      if(arr[arr.length-2]>arr[arr.length-1])
      {
         int temp = 0;
         temp = arr[arr.length-1];
         arr[arr.length-1] = arr[arr.length-2];
         arr[arr.length-2] = temp;
      }
      return arr;
   }
}

就是多了一些初始化和一些输入的代码,用来检查一下程序错没错。

3.1 效果

自动生成:

6,11,15,21,22,1,14
10,22,25,28,29,4,14
5,9,16,24,29,1,11
3,4,15,21,23,6,10
7,12,15,24,27,5,10
1,2,6,14,26,8,13
5,6,10,24,31,4,8
6,14,17,18,26,1,8
3,7,12,23,29,1,10
10,15,19,21,29,3,4


结果:8,13,20,30,32,2,7

自动生成:

5,10,15,19,28,4,14
3,5,12,16,25,8,9
10,21,24,26,27,8,12
1,5,12,21,30,3,15
3,6,14,19,31,4,11
3,9,18,24,26,4,15
9,24,27,28,30,7,10
2,17,18,26,30,10,12
3,11,21,27,28,8,12
3,9,10,27,30,14,15

结果:4,7,8,13,20,1,2

  游戏开发 最新文章
6、英飞凌-AURIX-TC3XX: PWM实验之使用 GT
泛型自动装箱
CubeMax添加Rtthread操作系统 组件STM32F10
python多线程编程:如何优雅地关闭线程
数据类型隐式转换导致的阻塞
WebAPi实现多文件上传,并附带参数
from origin ‘null‘ has been blocked by
UE4 蓝图调用C++函数(附带项目工程)
Unity学习笔记(一)结构体的简单理解与应用
【Memory As a Programming Concept in C a
上一篇文章      下一篇文章      查看所有文章
加:2022-04-06 16:21:40  更:2022-04-06 16:22:40 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/16 19:57:09-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码