IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> 菜鸟升级日记8 -> 正文阅读

[数据结构与算法]菜鸟升级日记8

面向对象

稀疏数组

本来是打算偷懒不写这个内容的,但昨天看了一下数据结构的网课,发现里面也讲了稀疏数组,所以还是把它过一遍比较好。

普通数组和稀疏数组的区别

稀疏数组的代码实现

将普通数组转化为稀疏数组

1.先建立普通数组

int[][] array=new int[5][7];
array[0][2]=1;
array[1][3]=2;
array[2][4]=3;
for(int[] row:array){ //打印出二维数组
 ? ?for(int i:row){
 ? ? ? ?System.out.print(i+" ");
 ?  }
 ? ?System.out.println();
}

2.再建立稀疏数组

稀疏数组的第0行的三个数分别是二维数组的行、列和有效值的个数;

稀疏数组的行数是二维数组的有效值的个数加一,列数为3;

则需要遍历二维数组,找出有效值的个数。

int count=0;
for(int i=0;i<5;i++){
 ? ?for(int j=0;j<7;j++){
 ? ? ? ?if(array[i][j]!=0){
 ? ? ? ? ? ?count++;
 ? ? ?  }
 ?  }
}
int[][] sparse=new int[count+1][3];
sparse[0][0]=5;
sparse[0][1]=7;
sparse[0][2]=count;
int sum=0;
for(int i=0;i<array.length;i++){
 ? ?for(int j=0;j<array[i].length;j++){
 ? ? ? ?if(array[i][j]!=0){
 ? ? ? ? ? ?sum++;
 ? ? ? ? ? ?sparse[sum][0]=i;
 ? ? ? ? ? ?sparse[sum][1]=j;
 ? ? ? ? ? ?sparse[sum][2]=array[i][j];
 ? ? ?  }
 ?  }
}

3.打印出稀疏数组

for(int[] num:sparse){
 ? ?for(int a:num){
 ? ? ? ?System.out.println(a+" ");
 ?  }
 ? ?System.out.println();
}

4.将稀疏数组还原成二维数组

int[][] array2=new int[sparse[0][0]][sparse[0][1]];
for(int i=1;i<sparse.length;i++){
 ? ? ? array2[sparse[i][0]][sparse[i][1]]=sparse[i][2];
}
for(int[] nums:array2) {
            for(int b:nums) {
                System.out.print(b+" ");
            }
            System.out.println();
        }

运行结果如下:

封装

高内聚,低耦合

  • private属性私有,在其他类中不能直接使用

    private String name;
    private int age;
  • 在其他类中调用时,要提供一些public的get,set方法

    提供get,set方法

    public String getName(){ //get获得这个数据
     ? ?return this.name;
    }
    public void setName(){ //set给这个数据设值
     ? ?this.name=name;
    }

    在其他类中调用

    Student s1=new Student();
    s1.setName("喜羊羊");
    System.out.println(s1.getName());

封装的作用

  • 提高程序的安全性,保护数据;

  • 隐藏代码的实现细节;

  • 统一接口;

  • 系统的可维护性增加了。

继承

  • Java中类只有单继承,没有多继承;

  • super

    1. super调用父类的构造方法,必须在构造方法的第一个;

    2. super只能出现在子类的方法或者构造方法中;

    3. super和this不能同时调用构造方法(与类名相同的方法)。

  • super VS this

    1. 代表的对象不同:this本身调用这个对象

      super代表父类对象的应用

    2. 前提:this没有继承也可以使用

      super只能在继承条件下使用

    3. 构造方法:this() 本类的构造

      super() 父类的构造

      父类

      public class Person{
       ? ?public void print(){
       ? ? ? ?System.out.println("Person");
       ?  }
      }

      子类

      public class Student extends Person{
       ? ?public void print(){
       ? ? ? ?System.out.println("Student");
       ?  }
       ? ?public void test1(){
       ? ? ? ?print(); //Student
       ? ? ? ?this.print(); //Student
       ? ? ? ?super.print(); //Person
       ?  }
      }

      测试类

      public class Application{
       ? ?public static void main(String[] args){
       ? ? ? ?Student s1=new Student();
       ? ? ? ?s1.test1();
       ?  }
      }

    方法重写

    前提:需要有继承关系,子类重写父类的方法。

    静态方法:方法的调用只和左边定义的数据类型有关。

    非静态方法:重写

    1. 方法名必须相同;

    2. 参数列表必须相同;

    3. 修饰符:范围可以扩大但不能缩小

    4. 抛出异常:范围可以缩小但不能扩大

方法实现重现时

方法未实现重写时

_____________________________________________________________________________

又断更了好长时间,今天刚去学校报道完,忙了好久。

刚进寝室,就看见我的床帘塌了,不过幸运的是,没有发现发霉现象。

感觉这个学期会开始忙起来了,自己要改变的地方也很多,而且要在短时间内——坚持健身、不要过于在意别人的眼光和想法、自律等等,努力让自己再次发光吧!

  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2021-09-06 11:24:08  更:2021-09-06 11:25:17 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/26 1:40:36-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码