实验----Java的二维数组的应用及杨辉三角的编写
(1) 编写一个程序,生成一个10*10的二维随机整数数组,并将该数组的每行最大值保存于一个一维数组中,将每列平均值保存于另外一个一维数组中并分别输出。
(2) 编程输出杨辉三角的前10行。
找出一个,即该位置上的元素在该行上最大,在该列上最小(注:一个二维数组也可能没有这样的鞍点)。
/**
*
* @author liuhui
*@version Java上机实验三
*@time 2016.10.30
*/
public class javatest2 {
public static int line = 0,row = 0;
public static void main(String[] args) { //主函数
int b[][] = array();
int c[] = linearArray(b);
double d[] = average(b);
printArrayOne(b);
System.out.println();
printArrayTwo(c);
System.out.println();
printArrayTwo(d);
System.out.println();
triangle aTriangle = new triangle();
aTriangle.print();
int f[] = saddle(b, c);
for(int i=0;i<f.length;i++)
{
if(f[i]==-1)
break;
else
System.out.print(f[i]+" ");
}
}
public static int[][] array() //获得随机二维数组
{
int a[][] = new int[10][10];
for(int i=0;i<10;i++)
{
for(int j=0;j<10;j++)
{
int r = (int) (Math.random()*10);
a[i][j] = r;
}
}
return a;
}
public static void printArrayOne(int a[][]) //打印二维数组
{
for(int i=0;i<10;i++)
{
System.out.println();
for(int j=0;j<10;j++)
{
System.out.print(a[i][j]);
System.out.print(" ");
}
}
System.out.println();
}
public static void printArrayTwo(int a[]) //打印一维数组
{
for(int i=0;i<10;i++)
{
System.out.print(a[i]+" ");
}
}
public static void printArrayTwo(double a[])
{
for(int i=0;i<10;i++)
{
System.out.print(a[i]+" ");
}
}
public static int[] linearArray(int a[][]) //求每行数组的最大值
{
int max = 0;
int b[] = new int[10];
for(int i=0;i<10;i++)
{
for(int j=0;j<10;j++)
{
if(max<a[i][j])
{
max = a[i][j];
line = i;
row = j;
}
}
b[i] = max;
max = 0;
}
return b;
}
public static double[] average(int a[][]) //求每列数组的平均数
{
double b[] = new double[10];
double sum = 0.0;
for(int i=0;i<10;i++)
{
for(int j=0;j<10;j++)
{
sum = sum +a[i][j];
}
b[i] = sum/10;
sum = 0.0;
}
return b;
}
public static int []saddle(int a[][],int b[]) //判断鞍点
{
int c[] = new int [10];
int m = 0;
boolean k = true;
for(int i=0;i<10;i++)
{
for(int j=0;j<10;j++)
{
if(b[i]>a[j][row])
{
k = false;
break;
}
}
if(k==true)
{
c[m] = b[i];
m++;
}
}
if(k==false)
{
System.out.println("没有鞍点");
c[0] = -1;
}
return c;
}
}
class triangle{ //做杨辉三角
public void print()
{
int b[][] = new int[10][];
for(int i=0;i<10;i++)
b[i] = new int[i+1];
for(int i=0;i<10;i++)
{
for(int j=0;j<b[i].length;j++)
{
if(i==0||j==0||j==b[i].length-1)
b[i][j] = 1;
else
b[i][j] = b[i-1][j-1] + b[i-1][j];
}
}
for(int i=0;i<10;i++)
{
for(int k=9-i;k>=1;k--)
System.out.print(" ");
for(int j=0;j<i+1;j++)
{
System.out.print(b[i][j]+" ");
}
System.out.println();
}
}
}
实验----Java的二维数组的应用及杨辉三角的编写的更多相关文章
- Java的二维数组的应用及杨辉三角的编写
(1) 编写一个程序,生成一个10*10的二维随机整数数组,并将该数组的每行最大值保存于一个一维数组中,将每列平均值保存于另外一个一维数组中并分别输出. (2) 编程输出杨辉三角的前10行. 找出一个 ...
- Java基础--二维数组
1.二维数组的定义 二维数组表示行列二维结构,在栈空间中的二维数组的地址指向堆空间中的一维数组,堆空间中的一维数组的地址又指向一维数组所在的内存空间. 2.二维数组的声明 二维数组声明有3种方式,推荐 ...
- java、二维数组详解!
/* java 二维数组的概念 使用方法! 1.什么是二维数组? 答案:数组的数组! 他的每一个元素都是数组!二维数组是(存储一维数组的)一维数组. 2.如何定义?(以二维数组为列) int arr[ ...
- 剑指offer编程题Java实现——二维数组中的查找
题目描述 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数. 下面是我实现的代码 ...
- 晓莲说-何不原创:java 实现二维数组冒泡排序
新手从业路-为自己回顾知识的同时,也希望和大家分享经验: 话不多说,上代码 public class 冒泡排序 { /** * @param admin * @2017.12.4 ...
- 题目一:使用Java实现二维数组中的查找
考点:数组 题目:二维数组中的查找 描述:在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判 ...
- Java Array二维数组使用
二维数组:元素为一维数组的数组 package myArray.arrayarray; /* *二维数组:元素为一维数组的数组 * * 定义格式: * A:数组类型[][] 数组名: (推荐用法) * ...
- Java数组的应用:案例:杨辉三角,三维数组,字符串数组
//import java.util.Arrays; //包含Arrays //import java.util.Random; public class HelloWorld { public st ...
- 【转载】java定义二维数组问题。分清数组与集合的区别
出处: 度娘知道 答案由用户{ heitianba }提供. Q: int a[][] = new int[3][2]; a[0] = {1,6}; 报错:第二句是非法表达式.为什么? A: in ...
随机推荐
- 设计一个Mypoint类,求两个点之间的距离
package Test; public class test6 { public static void main(String[] args) { // TODO Auto-generated m ...
- [Python之路] 多种方式实现并发Web Server
下面我们使用Python来实现并发的Web Server,其中采用了多进程.多线程.协程.单进程单线程非阻塞的方式. 一.使用子进程来实现并发Web Server 参照 https://www.cnb ...
- jQuery.post(url, [data], [callback], [type])
jQuery.post(url, [data], [callback], [type]) 概述 通过远程 HTTP POST 请求载入信息. 这是一个简单的 POST 请求功能以取代复杂 $.ajax ...
- 读狼书,重温flask
最近做个简单的MIS系统, 趁机读<flask web 开发实战 入门.进阶与原理解析> 李辉. 由于是flask官方团队的人写的.方方面面都很细致. 很多写法.配置,和之前0.X时代也 ...
- 「美团 CodeM 初赛 Round A」试题泛做
最长树链 树形DP.我们发现gcd是多少其实并不重要,只要不是1就好了,此外只要有一个公共的质数就好了.计f[i][j]表示i子树内含有j因子的最长链是多少.因为一个数的不同的质因子个数是log级别的 ...
- matplotlib(二):折线图
import numpy as np import matplotlib.pyplot as plt import matplotlib.dates as mdates # 解决中文显示问题 plt. ...
- C语言中的位域[转]
有些信息在存储时,并不需要占用一个完整的字节,而只需要一个或几个二进制位即可;比如:在存放一个开关量时,只有0和1两种状态,只需要使用一个二进制位即可存储;为了节省存储空间,C语言提供了一种数据结构, ...
- 五、在事务中使用Mybatis缓存的那些坑
场景: 1.同一个事务中 2.使用mybatis执行同一个sql @Transactional(rollbackFor = { Exception.class }) public void getIn ...
- Vue_(组件通讯)子组件向父组件传值
Vue组件 传送门 子组件向父组件传值:子组件通过$.emit()方法以事件形式向父组件发送消息传值: 使用步骤: 1.定义组件:现有自定义组件com-a.com-b,com-a是com-b的父组件: ...
- [BZOJ1123]:[POI2008]BLO(塔尖)
题目传送门 题目描述 Byteotia城市有n个towns.m条双向roads.每条road连接两个不同的towns,没有重复的road.所有towns连通. 输入格式 输入n,m及m条边. 输出格式 ...