实验----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 ...
随机推荐
- Python文件查找
#!/usr/bin/python import os import string def get_name(path_name, file_str): dir_name = ...
- ASP.NET MVC5入门指南(2)*入门介绍*创建您的第一个应用
开始吧 首先安装Visual Studio 2017.然后,打开Visual Studio. Visual Studio是一个IDE或集成开发环境.就像使用Microsoft Word编写文档一样,您 ...
- Confluence 6 上传一个附加文件的新版本
有下面 2 种方法来上传一个附加文件的新版本,你可以: 上传与已有附件具有相同文件名的版本. 使用 上传一个新版本(Upload a new version) 按钮来进行上传(这个在文件预览界面中 ...
- [JOI2012春季合宿]Rotate (链表)
题意 题解 又是一道神仙题-- 显然的做法是大力splay,时间复杂度\(O((N+Q)N\log N)\), 可以卡掉. 正解: 使用十字链表维护矩阵,在周围增加第\(0\)行/列和第\((n+1) ...
- MySQL_(Java)【连接池】简单在JDBCUtils.java中创建连接池
MySQL_(Java)[事物操作]使用JDBC模拟银行转账向数据库发起修改请求 传送门 MySQL_(Java)[连接池]使用DBCP简单模拟银行转账事物 传送门 Java应用程序访问数据库的过程: ...
- js获取当前页面url信息
<html> <head> <meta charset="utf-8" /> <title></title> <s ...
- spiderkeeper使用教程
安装包 pip install scrapy pip install scrapyd pip install scrapyd-client pip install spiderkeeper 进入到sc ...
- 安卓 API 19 低版本设置自带的圆圈效果
在 Android API 19 环境下,RadioButton 消除或者自定义自带的圆圈效果的形式来设置: 自定义自身选择图标 android:button="@drawable/sele ...
- SRS之RTMP handshake
1. SrsRtmpServer::handshake 位于 srs_rtmp_stack.cpp. int SrsRtmpServer::handshake() { int ret = ERROR_ ...
- 解决autowaired注入时机问题
package com.haiyisoft.loveLifeWeb.config; import javax.annotation.PostConstruct; import org.springfr ...