2. 定义一个二维整形数组data[5][6],数组中的元素在区间[0, 100)上随机赋值。找出数组中所有的具有这类性质的元素及其位置:该元素在所在行是最大的,但在其所在列是最小的。如果没有这样的元

本文主要是介绍2. 定义一个二维整形数组data[5][6],数组中的元素在区间[0, 100)上随机赋值。找出数组中所有的具有这类性质的元素及其位置:该元素在所在行是最大的,但在其所在列是最小的。如果没有这样的元,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

package monster.zf.Test;
/*** 	2. 	* 	 	定义一个二维整形数组data[5][6],数组中的元素在区间[0, 100)上随机赋值。* 		找出数组中所有的具有这类性质的元素及其位置:该元素在所在行是最大的,但在其所在列是最小的。* 		如果没有这样的元素,则输出“没有这样的元素”。* @remakeTODO* @author Conquer丶ZF* @date 2019年9月12日下午12:53:31*/
public class FindArray {public static void main(String[] args) {int[][] data = new int[5][6];for (int i = 0; i < data.length; i++) {for (int j = 0; j < data[i].length; j++) {data[i][j] = (int)(Math.random()*100 )% 101;//产生[a-b]之间的一个整型随机数,//公式为:(int)(Math.random()*10000) % (b - a + 1) + a;}	}//int data[][] = {{1,2,11},{4,5,12},{7,8,9}};//测试验证的数组System.out.println("随机产生的数组为:");for (int i = 0; i < data.length; i++) {for (int j = 0; j < data[i].length; j++) {					System.out.print(data[i][j] + "\t");					}System.out.println();//打印完一行就换行	}findandian(data);}public static void findandian(int array[][]){boolean flag = true;for (int i = 0; i < array.length; i++) {  //找出第i行的最大数int max = array[i][0]; //开始时假设a[i][0]最大int max_j = 0;        //记录此时的列下标for (int j = 0; j < array[i].length; j++) {if(array[i][j]>max){max = array[i][j]; //将本行的最大数放在max中max_j = j;        //同时记录此时的列号}else continue;}for ( int k = 0; k < array.length; k++) {if(max > array[k][max_j]){  //将最大数和其同列相比flag = false;//只要max不是同列最小的就不是鞍点,设置为false		break;}else if(k==array.length-1){//当然循环到最后一个了就说明都满足是鞍点。就设置为trueflag = true;}else{continue; //否则就继续}	}if(flag){System.out.println("位置第" + (i+1) + "行," + (max_j+1) + "列的"+array[i][max_j] + "是鞍点" );//如果max比同列的都小就说明是鞍点,就输出}else{System.out.println("第"+(i+1) + "行"+"不存在鞍点,即没有这样的元素" );}}}
}

在这里插入图片描述

由于5行6列0-100随机数生产的鞍点太少了所以举个测试用例

测试数组

在这里插入图片描述
在这里插入图片描述

这篇关于2. 定义一个二维整形数组data[5][6],数组中的元素在区间[0, 100)上随机赋值。找出数组中所有的具有这类性质的元素及其位置:该元素在所在行是最大的,但在其所在列是最小的。如果没有这样的元的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/250704

相关文章

JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法

《JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法》:本文主要介绍JavaScript中比较两个数组是否有相同元素(交集)的三种常用方法,每种方法结合实例代码给大家介绍的非常... 目录引言:为什么"相等"判断如此重要?方法1:使用some()+includes()(适合小数组)方法2

Java中数组与栈和堆之间的关系说明

《Java中数组与栈和堆之间的关系说明》文章讲解了Java数组的初始化方式、内存存储机制、引用传递特性及遍历、排序、拷贝技巧,强调引用数据类型方法调用时形参可能修改实参,但需注意引用指向单一对象的特性... 目录Java中数组与栈和堆的关系遍历数组接下来是一些编程小技巧总结Java中数组与栈和堆的关系关于

把Python列表中的元素移动到开头的三种方法

《把Python列表中的元素移动到开头的三种方法》在Python编程中,我们经常需要对列表(list)进行操作,有时,我们希望将列表中的某个元素移动到最前面,使其成为第一项,本文给大家介绍了把Pyth... 目录一、查找删除插入法1. 找到元素的索引2. 移除元素3. 插入到列表开头二、使用列表切片(Lis

Django中的函数视图和类视图以及路由的定义方式

《Django中的函数视图和类视图以及路由的定义方式》Django视图分函数视图和类视图,前者用函数处理请求,后者继承View类定义方法,路由使用path()、re_path()或url(),通过in... 目录函数视图类视图路由总路由函数视图的路由类视图定义路由总结Django允许接收的请求方法http

MyBatis-Plus 自动赋值实体字段最佳实践指南

《MyBatis-Plus自动赋值实体字段最佳实践指南》MyBatis-Plus通过@TableField注解与填充策略,实现时间戳、用户信息、逻辑删除等字段的自动填充,减少手动赋值,提升开发效率与... 目录1. MyBATis-Plus 自动赋值概述1.1 适用场景1.2 自动填充的原理1.3 填充策略

python生成随机唯一id的几种实现方法

《python生成随机唯一id的几种实现方法》在Python中生成随机唯一ID有多种方法,根据不同的需求场景可以选择最适合的方案,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来一起学习学习... 目录方法 1:使用 UUID 模块(推荐)方法 2:使用 Secrets 模块(安全敏感场景)方法

Java中的数组与集合基本用法详解

《Java中的数组与集合基本用法详解》本文介绍了Java数组和集合框架的基础知识,数组部分涵盖了一维、二维及多维数组的声明、初始化、访问与遍历方法,以及Arrays类的常用操作,对Java数组与集合相... 目录一、Java数组基础1.1 数组结构概述1.2 一维数组1.2.1 声明与初始化1.2.2 访问

C# 比较两个list 之间元素差异的常用方法

《C#比较两个list之间元素差异的常用方法》:本文主要介绍C#比较两个list之间元素差异,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. 使用Except方法2. 使用Except的逆操作3. 使用LINQ的Join,GroupJoin

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方