第01篇 稀疏数组

一、介绍

当一个数组(通常指二维数组)的大部分数据数据内容相同,少数数据不同的时候,那么我们可以用稀疏数组对原始数组进行压缩,从而达到节省空间的目的。

二、特点

稀疏数组有以下特点:

  1. 行数不固定,列数固定为3;
  2. 第一行的元素分别为:第一列是原始数组的行数、第二列是原始数组的列数、第三列是原始数组中除了默认值(就是大多数值,这个不保存)之外其他值的个数
  3. 其他行每行记录原始数组中某个数据的行下标、列下标、值
    如:
0	0	0	0	1	
0	0	0	1	0	
0	0	0	2	0	
0	0	2	2	0	

转换为稀疏数组的结果如下

4	5	5	
0	4	1	
1	3	1	
2	3	2	
3	2	2	
3	3	2	

三、实现分析

(一)原始数组转稀疏数组

  1. 遍历原始数组所有元素,找出不是默认值的元素的个数sum,那么稀疏数组的行数就是sum+1(第一行保存的不是元素信息),创建稀疏数组sparseArray[sum+1][3]
  2. 按照特点的第2点对第一行进行赋值
  3. 遍历原始数组,给其他行赋值,这里需要借助一个下标来记录是在记录第几个元素的信息(行、列、值)

(二)稀疏数组恢复成原始数组

  1. 读取第一行,从而构建出原始数组;
  2. 给数组的所有元素赋值上默认值;
  3. 遍历稀疏数组,给非默认值的位置赋予正确的值。

四、代码实现

package com.firewolf.javabase.s001_sparsearray;

/**
 * 稀疏数组
 */
public class SparseArrayUtil {

  /**
   * 把二维数组转换成稀疏数组
   *
   * @param array : 需要被转换的数组
   * @param defaultValue :默认的值,这个值不用存储
   * @return 转换后的稀疏数组
   */
  public static Number[][] parseToSparseArray(Number[][] array, Number defaultValue) {

    //1.获取数组中不为默认值的元素个数,
    int sum = 0;
    for (Object[] row : array) {
      for (Object el : row) {
        if (!defaultValue.equals(el)) {
          sum++;
        }
      }
    }

    //构建稀疏数组
    Number[][] sparseArray = new Number[sum + 1][3]; //只有3列
    //2.稀疏数组中第一列:原始数组行、原始数组列、元素总个数
    sparseArray[0][0] = array.length;
    sparseArray[0][1] = array[0].length;
    sparseArray[0][2] = sum;

    //3.剩余的每行分别显示的是非默认值的元素信息:行下标、列下标、值
    int row = 1;
    for (int i = 0; i < array.length; i++) {
      for (int j = 0; j < array[0].length; j++) {
        if (!array[i][j].equals(defaultValue)) {
          sparseArray[row][0] = i;
          sparseArray[row][1] = j;
          sparseArray[row][2] = array[i][j];
          row += 1;
        }
      }
    }
    return sparseArray;
  }


  /**
   * 把二维数组转换成稀疏数组,默认元素为0
   *
   * @param array : 需要被转换的数组
   * @return 转换后的稀疏数组
   */
  public static Number[][] parseToSparseArray(Number[][] array) {
    return parseToSparseArray(array, 0);
  }


  /**
   * 把稀疏数组转换成正常数组
   *
   * @param sparseArray 稀疏数组
   * @param defalutValue 默认值
   * @return 从稀疏数组恢复出来的正常数组
   */
  public static Number[][] parseFromSparseArray(Number[][] sparseArray, Number defalutValue) {

    //1.从第一行提取原数组的行数、列数,从而初始化数组
    int rows = sparseArray[0][0].intValue(); //行数
    int cols = sparseArray[0][1].intValue(); //列数
    int sum = sparseArray[0][2].intValue();//元素总个数
    Number[][] array = new Number[rows][cols];


    //2.先全部都给上默认值
    for (int i = 0; i < rows; i++) {
      for (int j = 0; j < cols; j++) {
        array[i][j] = defalutValue;
      }
    }

    //3. 恢复稀疏数据
    for (int i = 1; i <= sum; i++) {
      array[sparseArray[i][0].intValue()][sparseArray[i][1].intValue()] = sparseArray[i][2];
    }
    return array;
  }


  /**
   * 把稀疏数组转换成正常数组,默认填充元素为0
   *
   * @param sparseArray 稀疏数组
   * @return 从稀疏数组恢复出来的正常数组
   */
  public static Number[][] parseFromSparseArray(Number[][] sparseArray) {
    return parseFromSparseArray(sparseArray, 0);
  }


  /**
   * 显示二维数组
   *
   * @param array 要显示的数组
   */
  public static void showArray(Number[][] array) {
    for (Number[] row : array) {
      for (Number el : row) {
        System.out.print(el.toString() + "\t");
      }
      System.out.println();
    }
  }
}

下载方式:https://pan.quark.cn/s/c9b9b647468b ### 初级JSP程序设计教程核心内容解析#### 一、JSP基础概述JSP(JavaServer Pages)是由Sun Microsystems公司创建的一种动态网页技术规范,主要应用于构建动态网站及Web应用。JSP技术使得开发者能够将动态数据与静态HTML文档整合,从而实现网页内容的灵活性和可变性。##### JSP的显著特性:1. **动态与静态内容的分离**:JSP技术支持将动态数据(例如数据库查询结果、实时时间等)嵌入到静态HTML文档中。这种设计方法增强了网页的适应性和可维护性。2. **易用性**:开发者可以利用常规的HTML编辑工具来编写静态部分,并通过简化的标签技术将动态内容集成到页面中。3. **跨平台兼容性**:基于Java平台的JSP具有优良的跨操作系统运行能力,能够在多种不同的系统环境中稳定工作。4. **强大的后台支持**:JSP能够通过JavaBean组件访问后端数据库及其他资源,以实现复杂的数据处理逻辑。5. **执行效率高**:JSP页面在初次被请求时会被转换为Servlet,随后的请求可以直接执行编译后的Servlet代码,从而提升了服务响应的效率。#### 二、JSP指令的运用JSP指令用于设定整个JSP页面的行为规范。这些指令通常放置在页面的顶部,向JSP容器提供处理页面的相关指导信息。##### 主要的指令类型:1. **Page指令**: - **语法结构**:`<%@ page attribute="value" %>` - **功能**:定义整个JSP页面的运行特性,如设定页面编码格式、错误处理机制等。 - **实例**: ...
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值