(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的二维数组的应用及杨辉三角的编写的更多相关文章

  1. Java的二维数组的应用及杨辉三角的编写

    (1) 编写一个程序,生成一个10*10的二维随机整数数组,并将该数组的每行最大值保存于一个一维数组中,将每列平均值保存于另外一个一维数组中并分别输出. (2) 编程输出杨辉三角的前10行. 找出一个 ...

  2. Java基础--二维数组

    1.二维数组的定义 二维数组表示行列二维结构,在栈空间中的二维数组的地址指向堆空间中的一维数组,堆空间中的一维数组的地址又指向一维数组所在的内存空间. 2.二维数组的声明 二维数组声明有3种方式,推荐 ...

  3. java、二维数组详解!

    /* java 二维数组的概念 使用方法! 1.什么是二维数组? 答案:数组的数组! 他的每一个元素都是数组!二维数组是(存储一维数组的)一维数组. 2.如何定义?(以二维数组为列) int arr[ ...

  4. 剑指offer编程题Java实现——二维数组中的查找

    题目描述 在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判断数组中是否含有该整数.   下面是我实现的代码 ...

  5. 晓莲说-何不原创:java 实现二维数组冒泡排序

    新手从业路-为自己回顾知识的同时,也希望和大家分享经验: 话不多说,上代码 public class 冒泡排序 { /**     * @param admin     * @2017.12.4   ...

  6. 题目一:使用Java实现二维数组中的查找

    考点:数组       题目:二维数组中的查找   描述:在一个二维数组中,每一行都按照从左到右递增的顺序排序,每一列都按照从上到下递增的顺序排序.请完成一个函数,输入这样的一个二维数组和一个整数,判 ...

  7. Java Array二维数组使用

    二维数组:元素为一维数组的数组 package myArray.arrayarray; /* *二维数组:元素为一维数组的数组 * * 定义格式: * A:数组类型[][] 数组名: (推荐用法) * ...

  8. Java数组的应用:案例:杨辉三角,三维数组,字符串数组

    //import java.util.Arrays; //包含Arrays //import java.util.Random; public class HelloWorld { public st ...

  9. 【转载】java定义二维数组问题。分清数组与集合的区别

    出处: 度娘知道 答案由用户{ heitianba }提供. Q: int a[][] = new int[3][2];  a[0] = {1,6};  报错:第二句是非法表达式.为什么? A: in ...

随机推荐

  1. 设计一个Mypoint类,求两个点之间的距离

    package Test; public class test6 { public static void main(String[] args) { // TODO Auto-generated m ...

  2. [Python之路] 多种方式实现并发Web Server

    下面我们使用Python来实现并发的Web Server,其中采用了多进程.多线程.协程.单进程单线程非阻塞的方式. 一.使用子进程来实现并发Web Server 参照 https://www.cnb ...

  3. jQuery.post(url, [data], [callback], [type])

    jQuery.post(url, [data], [callback], [type]) 概述 通过远程 HTTP POST 请求载入信息. 这是一个简单的 POST 请求功能以取代复杂 $.ajax ...

  4. 读狼书,重温flask

    最近做个简单的MIS系统, 趁机读<flask web 开发实战 入门.进阶与原理解析> 李辉.  由于是flask官方团队的人写的.方方面面都很细致. 很多写法.配置,和之前0.X时代也 ...

  5. 「美团 CodeM 初赛 Round A」试题泛做

    最长树链 树形DP.我们发现gcd是多少其实并不重要,只要不是1就好了,此外只要有一个公共的质数就好了.计f[i][j]表示i子树内含有j因子的最长链是多少.因为一个数的不同的质因子个数是log级别的 ...

  6. matplotlib(二):折线图

    import numpy as np import matplotlib.pyplot as plt import matplotlib.dates as mdates # 解决中文显示问题 plt. ...

  7. C语言中的位域[转]

    有些信息在存储时,并不需要占用一个完整的字节,而只需要一个或几个二进制位即可;比如:在存放一个开关量时,只有0和1两种状态,只需要使用一个二进制位即可存储;为了节省存储空间,C语言提供了一种数据结构, ...

  8. 五、在事务中使用Mybatis缓存的那些坑

    场景: 1.同一个事务中 2.使用mybatis执行同一个sql @Transactional(rollbackFor = { Exception.class }) public void getIn ...

  9. Vue_(组件通讯)子组件向父组件传值

    Vue组件 传送门 子组件向父组件传值:子组件通过$.emit()方法以事件形式向父组件发送消息传值: 使用步骤: 1.定义组件:现有自定义组件com-a.com-b,com-a是com-b的父组件: ...

  10. [BZOJ1123]:[POI2008]BLO(塔尖)

    题目传送门 题目描述 Byteotia城市有n个towns.m条双向roads.每条road连接两个不同的towns,没有重复的road.所有towns连通. 输入格式 输入n,m及m条边. 输出格式 ...