JAVA生成一个二维数组,使中间元素不与相邻的9个元素相等,并限制每一个元素的个数
JAVA生成一个二维数组,使中间元素不与相邻的9个元素相等,并限制每一个元素的个数
示例如下
至少需要九个元素:"A","B","C","D","E","F","G","H","I"
我们打印一个30*15的二维数组
刚好限制每一个元素出现50次
I D H A C F E G B E F C B I A
G A E D H I B F H G D G H C E
D F I B C A C G D B I A E F H
A H C G I D B E F E H G B C D
F I A F C A G I H D B E A I F
D E H G B E C A F I G H D C B
F B C I D H G E G A E C I A H
D H F B F C I A B D G H E D I
C E A G H B F C E F I B G A F
D G I B A C D H B G E D H C I
E A F C H F E G I D A B G A E
I C H D B G C F E H F D I B C
A D E F H A I G B C A H G D E
I F B A C G F H E I D B A H B
D G I E F B C D G A H I E C F
H C B G D I F E F B D A G I H
A E F C E H B C I G I H D A C
F G B D A C E F D B E A G I H
C H I F B D A G E F D I B E G
A G C H I F C D H B E A H D B
E I F A G B I G C A C F E A H
D B G D I F E H F I E B C G D
A C H B A H D I E G C F D B A
F I E C G B E H C D A G H F I
D H G I F C A B E F E B I G D
A C A H G B D F C H I F E C A
I H G B E C A B D F G D H I E
A D C H I F E G C B I A G B D
E H F E A C B D F H G H I E G
C A D B I F H C G I F E B A D
A_50 B_50 C_50 D_50 E_50 F_50 G_50 H_50 I_50
代码如下:
package com.lc.array;
import java.util.ArrayList;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Random;
import java.util.Set;
import java.util.TreeMap; /**
* 生成数组
* @author Cheng
*/
public class MatrixManage {
private Integer hight = 30;
private Integer wide = 15;
private Integer max = 50;
/** 每个元素出现的个数 **/
private TreeMap<String, Integer> keyNumMap = new TreeMap<>();
/** 目标数组 **/
private String[][] arr = new String[hight][wide];
/** 每个点 可使用的元素集合 **/
private Map<String,Set<String>> pointMap = new TreeMap<>(); public MatrixManage(String[] keys, Integer hight, Integer wide, Integer max) { if((hight*wide)>max*(keys.length)){
System.out.println("二逼,("+hight+"*" + wide + ")大于("+max+"*"+keys.length+")了,还玩毛");
return;
} this.hight = hight;
this.wide = wide;
this.max = max;
this.arr = new String[hight][wide]; for(String key :keys){
keyNumMap.put(key, 0);
}
} private void addKeyNumMap(String key){
keyNumMap.put(key, keyNumMap.get(key)+1);
} private void subtractKeyNumMap(String key){
keyNumMap.put(key, keyNumMap.get(key)-1);
} public static void main(String[] args) {
MatrixManage entity = new MatrixManage(new String[]{"A","B","C","D","E","F","G","H","I"},30,15,50);
entity.print();
} private void print() { for(int i=0;i<hight;i++){ for(int j=0;j<wide;j++){ while(true){ String pointKey = i + "_" + j;//点的key if(pointMap.containsKey(pointKey)){// 是否存储过该点 Set<String> pointSet = pointMap.get(pointKey);//获取该点可用的元素集合 subtractKeyNumMap(arr[i][j]); //更新元素的数量 pointSet.remove(arr[i][j]); //删除目前的元素 if(pointSet.isEmpty()){//该点没有可用的元素 pointMap.remove(pointKey);//删除该点、后退 if(j==0){
i--;
j=wide-1;
}else{
j--;
} }else{ TreeMap<Integer, List<String>> usableMap = getUsableMap(pointSet, false); if(usableMap.isEmpty()){//该点没有可用的元素 pointMap.remove(pointKey);//删除该点、后退 arr[i][j]=null;
if(j==0){
i--;
j=wide-1;
}else{
j--;
}
}else{
arr[i][j] = getKey(usableMap);
break;
}
} }else{ Set<String> set = getRoundSet(i, j);//(右上方4个)环绕的数组集合 TreeMap<Integer, List<String>> usableMap = getUsableMap(set, true); if(usableMap.isEmpty()){ if(j==0){
i--;
j=wide-1;
}else{
j--;
} }else{ Set<String> tempSet = new HashSet<>();
for(List<String> l:usableMap.values()){
tempSet.addAll(l);
} arr[i][j] = getKey(usableMap); tempSet.remove(arr[i][j]);
pointMap.put(pointKey, tempSet);
break;
}
}
} //修改元素的数量
addKeyNumMap(arr[i][j]);
}
}
printArr();
printKeyNum();
} /**
* 获取key
* @param usableMap
* @return
*/
private String getKey(TreeMap<Integer, List<String>> usableMap) {
Map.Entry<Integer,List<String>> entry = usableMap.firstEntry();
Random random = new Random();
int s = random.nextInt(entry.getValue().size());
return entry.getValue().get(s);
} /**
* 获取可用集合
* @param treeMap
* @param set
* @param b 1、true set包含 2、 false set不包含
* @return
*/
private TreeMap<Integer, List<String>> getUsableMap(Set<String> set,boolean b) {
TreeMap<Integer,List<String>> usableMap = new TreeMap<>();
for(Map.Entry<String, Integer> entry:keyNumMap.entrySet()){
if(entry.getValue() < max){
if((b==true && !set.contains(entry.getKey())) || (b==false && set.contains(entry.getKey()))){
if(usableMap.get(entry.getValue())==null){
usableMap.put(entry.getValue(),new ArrayList<>());
}
usableMap.get(entry.getValue()).add(entry.getKey());
}
}
}
return usableMap;
} /**
* 获取周围的元素集合
* @param i
* @param j
* @return
*/
private Set<String> getRoundSet(int i, int j) {
Set<String> set = new HashSet<>();
for(int x=1;x>=0;x--){
if((i-x)>=0){
for(int y=-1;y<2;y++){ if(x==0 && y==0){
break;
} if((j+y)>=0 && (j+y)<wide){
set.add(arr[i-x][j+y]);
}
}
}
}
return set;
} /**
* 打印数组
*/
private void printArr() {
for(int i=0;i<arr.length;i++){
for(int j=0;j<arr[i].length;j++){
System.out.print(arr[i][j]+"\t");
}
System.out.println();
}
} /**
* 打印数组数
*/
private void printKeyNum() {
for(Map.Entry<String, Integer> entry:keyNumMap.entrySet()){
System.out.print(entry.getKey()+"_"+entry.getValue()+"\t");
}
} }
注:支持后退操作,解决了不符合条件的情况
JAVA生成一个二维数组,使中间元素不与相邻的9个元素相等,并限制每一个元素的个数的更多相关文章
- java例题_29 二维数组问题,并输出对角线之和
1 /*29 [程序 29 求矩阵对角线之和] 2 题目:求一个 3*3 矩阵对角线元素之和 3 程序分析:利用双重 for 循环控制输入二维数组,再将 a[i][i]累加后输出. 4 */ 5 6 ...
- ytu 1050:写一个函数,使给定的一个二维数组(3×3)转置,即行列互换(水题)
1050: 写一个函数,使给定的一个二维数组(3×3)转置,即行列互换 Time Limit: 1 Sec Memory Limit: 128 MBSubmit: 154 Solved: 112[ ...
- Java中的二维数组
Java 中的二维数组 所谓二维数组,可以简单的理解为是一种"特殊"的一维数组,它的每个数组空间中保存的是一个一维数组. 那么如何使用二维数组呢,步骤如下: 1. 声明数组并分配空 ...
- java学习之二维数组
java当中的二维数组,存储一组比较特殊的对象.他存储一个数组,同时存储的数组当中又存储着元素. java二维数组的声明方式一: class Arr2Demo { public static void ...
- Java生成艺术二维码也可以很简单
原文点击: Quick-Media Java生成艺术二维码也可以很简单 现在二维码可以说非常常见了,当然我们见得多的一般是白底黑块,有的再中间加一个 logo,或者将二维码嵌在一张特定的背景中(比如微 ...
- java基础之二维数组-杨辉三角
首先呢你要知道什么是杨辉三角? 答:杨辉三角,是二项式系数在三角形中的一种几何排列. 简单的说一下就是两个未知数和的幂次方运算后的系数问题,比如(x+y)的平方=x的平方+2xy+y的平方,这样系数就 ...
- Java基础教程——二维数组
二维数组 Java里的二维数组其实是数组的数组,即每个数组元素都是一个数组. 每个数组的长度不要求一致,但最好一致. // 同样有两种风格的定义方法 int[][] _arr21_推荐 = { { 1 ...
- Java一维与二维数组的拷贝与排序
Java一维与二维数组的拷贝与排序 目录 Java一维与二维数组的拷贝与排序 Arrays.sort() 一维数组升序排序 二维数组按行升序排序 二维数组按列升序排序 Java中的数组 Java中数组 ...
- [CareerCup] 13.10 Allocate a 2D Array 分配一个二维数组
13.10 Write a function in C called my2DAlloc which allocates a two-dimensional array. Minimize the n ...
随机推荐
- Android项目实战(四十九):Andoird 7.0+相机适配
解决方案类似: Android项目实战(四十):Andoird 7.0+ 安装APK适配 解决方法: 一.在AndroidManifest.xml 文件中添加 四大组件之一的 <provider ...
- IDEA基于Maven Struts2搭建配置及示例
1.web.xml加载struts框架即过滤器,要注意struts版本不同过滤器配置也不同. <!DOCTYPE web-app PUBLIC "-//Sun Microsystems ...
- 章节四、2-Switch语句
package introduction5; public class SwitchDemo { //switch用于固定值的判断,如星期.人的性别 //if用于判断区间.范围,能够用switch进行 ...
- Python绘图工具Plotly的简单使用
1.Plotly被称为史上最好的绘图工具之一,为了更好的展示金融数据的复杂性. Plotly的官方网站为:https://plot.ly/ python量化的关键是金融数据可视化,无论是传统的K线图, ...
- ORA-01440: column to be modified must be empty to decrease precision or scale
在修改表字段的NUMBER类型的精度或刻度时,你可能会遇到ORA-01440: column to be modified must be empty to decrease precision or ...
- ros中自定义消息 报错 ImportError: No module named em
大家好,欢迎来到我的博客,之前写的都是比较松散的,鉴于工作的原因,之后的随笔将持续更新ROS以及linux使用方面的随笔,欢迎大家留言,相互学习 ——————————————————————————— ...
- linux源
系统:centos7 x86_64 一.配置本地yum源 1.1加载光驱 1.2挂载到系统 注:如果要长期使用最好把整个镜像文件拷贝到系统下 1.3配置文件 路径/etc/yum.repos.d/ 打 ...
- c/c++ 通用的(泛型)算法 之 只读算法,写算法,排序算法
通用的(泛型)算法 之 只读算法,写算法,排序算法 只读算法: 函数名 功能描述 accumulate 求容器里元素的和 equal 比较2个容器里的元素 写算法 函数名 功能描述 fill 用给定值 ...
- 通过Socket实现TCP编程,用户登录之服务器相应客户端,客户端和服务端之间的通信
服务器端: 1.创建ServerSocket对象,绑定监听端口: 2.通过accept()方法监听客户端请求: 3.建立连接后通过输入流读取客户端发送的请求信息; 4.通过输出流向客户端发送响应信息; ...
- php 计算出一年中每周的周一日期
最近接到一个任务,归纳起来,就是:要算出每年当中,每周的周一日期.想了一会,看了下date函数,深入了解了一下date函数各个参数的含义之后,终于把这道题做出来了! 在date()函数中,有一个参数对 ...