一文了解JAVA的常用API

目录

    • 常用kpi
      • `math`
      • `System`
      • `Runtime`
      • `Object`
      • `Objects`
      • `BigInteger`
      • `BigDecima`
      • 正则表达式
      • 包装类

常用kpi

学习目的:

  • 了解类名和类的作用
  • 养成查阅api文档的习惯

math

工具类。因为是工具类,因此直接通过类名.方法名(形参)即可直接调用

  • abs:获取参数绝对值

    bug:传递的数必须在对应数据类型的取值范围内有相反数和他对应,如byte-128到127,-128没有值与之对应

  • ceil:向上取值,即向数轴的正方向取值(注意不是四舍五入)

  • floor:向下取值,即向数轴的负方向取值(注意不是四舍五入)

  • round:四舍五入,入到较近的偶数,如:

    12.51->13

    -12.49->-12

  • maxmin:取最值,底层是三元运算符

    max:两者之间取大值

    min:两者之间取小值

  • pow:获取a的b次幂

  • sqrt:返回开平方根后的值

  • cbrt:返回开立方根后的值

  • random:注意这里是math工具类中的random方法,不是Random类中的。math中的random底层还是创建了Random的对象然后采用nextDouble,math中的random:获取[0.0,1.0)之间的随机小数。

System

工具类。

计算机的时间原点:1970年1月1日 00:00:00->C语言的生日,我国:1970年1月1日 08:00:00

成员变量:

  • out:静态变量,因此可以用System.out调用,返回一个打印的对象

成员方法:

  • exit:终止虚拟机的运行,返回状态码,0是虚拟机正常停止;非0是虚拟机异常停止。不管是非0还是0,后面代码都不会执行

  • currenTimeMillis:返回当前系统的时间,以毫秒形式

  • arraycopy(数据源数组,起始索引,目的地数组,起始索引,拷贝个数):数组拷贝。

    • 细节1:如果两数组都是基本数据类型,那么它们必须是同一种数据类型,否则会报错。type mismatch异常
    • 细节2:需要考虑数组的长度,如果超出范围会报错。index out of bounds索引越界异常
    • 细节3:如果两数组都是引用数据类型,那么子类类型可以赋值给父类类型
      • 细节中的细节:如果此时想要将目的地数组中的父类地址打印出来,除了常规的for遍历、定义一个子类对象临时储存器之外,注意这时候要将父类强转后再赋值给子类对象临时储存器,不强转会报错(底层?)。可以类似理解成小可以自动转大,大则需要强转小,也是用水杯和水桶来理解。

Runtime

表示当前虚拟机的运行环境。

  • getRuntime:获取当前系统的运行环境对象。
    • 底层:Runtime类私有化了构造方法,不给外界创建对象,因此提供了get方法获取他的对象,不管在哪个类中,每次调用这个方法获取到的对象都是唯一的
  • exit:停止虚拟机。非静态,需要创建Runtime对象调用
  • availableProcessors:获取CPU的线程数
  • maxMemory:JVM能从系统中获得的总内存大小,单位字节
  • totalMemory:JVM已经从系统中获得的总内存大小,单位字节
  • freeMemory:JVM剩余内存大小
  • exec:运行cmd命令。比如指定时间关机选项。
    在这里插入图片描述

Object

Java中的顶级父类。

特点:

  • 没有成员变量,因为不可能所有子类都能抽取出一个共性来。
  • 只有无参构造,没有有参构造

成员方法:

  • toString:返回对象的字符串表现形式。该方法被public修饰,因此所有类的对象都可以在其虚方法表中调用这个方法,因为所有对象的类都默认继承于Object。

    • System.out.println(s)的底层:当我们在形参中输入一个对象类型的s时候,底层会尝试调用对象的toString方法,先在这个对象的类的成员方法中找,如果没有则在它的虚方法表中找,发现有该方法(从Object继承下来的),因此就会调用,把对象变成字符串。然后再打印在控制台上,打印完毕进行换行。toString的结论:如果不想这个对象打印字符串形式,而是想看到对象的内部属性(成员变量等),那么我们在该对象的类中重写Object的toString方法即可,在这个重写的方法的代码体中就可以打印对象的成员属性了
  • equals:比较两个对象是否相等。

    • equals的底层:用==号判断两个地址值是否相同,返回true和false。一般地址值对我们意义不大,如果不想比较地址值,想比较两个对象中的内部属性值,则在调用者的那个类重写equals方法即可。
    //用equals方法比较String和StringBuilder
    package com.itheima.a04objectdemo;
    public class ObjectDemo3 {
        public static void main(String[] args) {
            String s = "abc";
            StringBuilder sb = new StringBuilder("abc");
    
            System.out.println(s.equals(sb));// false
            //因为equals方法是被s调用的,而s属于String类,所以equals要看String类中的equals方法,而String类中的equals方法,源码是先判断形参sb是否为字符串,如果是字符串,再比较内部的属性,但是如果参数不是字符串,直接返回false
    
    
            System.out.println(sb.equals(s));// false
            //因为equals方法是被sb调用的,而sb是StringBuilder,所以这里的equals方法要看StringBuilder中的equals方法。而在StringBuilder当中,没有重写equals方法,使用的是Object中的,在Object当中默认是使用==号比较两个对象的地址值,而这里的s和sb记录的地址值是不一样的,所以结果返回false
        }
    }
    
    • clone:把A对象的属性值完全拷贝给B对象,也叫对象拷贝、复制。方法在底层会帮我们创建一个对象,并帮我们把原对象(调用者)的数据拷贝过去。

      **一些书写细节:**1、要让调用者子类重写Object中的clone方法,因为clone在Object中是用protected修饰的,在测试类中没有权限访问;2、让JavaBean类实现Cloneable接口;3、创建原对象并调用clone。

      • **浅克隆:**基本数据类型直接拷贝数据值,引用数据类型拷贝地址值。Object中的clone方法用的就是浅克隆。
      • 浅拷贝的内存图:
        在这里插入图片描述
  • **深克隆:**基本数据类型直接拷贝数据值,引用数据类型重新创建一个对象,特殊:对于直接赋值的字符串,是在串池管理的,这些会直接复用而不会创建新的空间

  • 深克隆的内存图:
    在这里插入图片描述

      • **实现深克隆的方式:**在重写的clone方法中自己改代码或者使用第三方工具类。
        • 方法一:自己重写方法
      //这是一个JavaBean类User,实现了一个接口Cloneable,表示这是可被克隆的,但是这个接口中没有抽象方法。如果一个接口里面没有抽象方法表示当前的接口是一个标记性接口。现在cloneable表示一旦实现了,那么当前类的对象就可以被克隆;如果没有实现,当前类的对象就不能克隆。(这里不懂,貌似是关于什么异常处理?)
      public class User implements Cloneable {
          private int id;
          private String username;
          private String password;
          private String path;
          private int[] data;  
      ----------------------------------------------------------------------------------------------
      //这里还是上面的JavaBean类User。重写Object类中的clone方法,以实现深克隆。
         @Override
          protected Object clone() throws CloneNotSupportedException {
              //先把被克隆对象中的数组获取出来
              int[] data = this.data;
              //创建新的数组
              int[] newData =new int[data.length];
              //拷贝数组中的数据
              for (int i = 0; i < data.length; i++) {
                  newData[i] = data[i];
              }
              //调用父类中的方法克隆对象
                  User u=(User)super.clone();
              //因为父类中的克隆方法是浅克隆,替换克隆出来对象中的数组地址值
              u.data =newData;
              return u;
          }
      
      • 方法2:采用第三方工具类。选中jar文件复制->在当前模块下新建一个包lib(library,可以把第三方代码都放在这)->粘贴->OK->导入后右键新导入的jar点击Add as Library->OK

Objects

工具类,提供了一些方法,免得我们自己做非空判断。

  • equals:先做非空判断,再判断两个对象。
    • 底层:方法的底层会判断s1是否为null,如果为null,直接返回false;如果s1不为null,那么就利用s1再次调用equals方法
      此时s1是student类型,所以最终还是会调用student中的equals方法。如果没有重写,比较地址值,如果重写了,就比较属性值。
  • isNull:判断对象是否为null,为null则返回true,否则返回false
  • nonNull:和isNull相反

BigInteger

用来创建很大的大整数。

构造方法:对象一旦创建,内部的值不能发生改变
在这里插入图片描述
构造方法注意:

  • 打印BigInteger对象是其中的数据值,不是地址值,因为在它的底层重写了父类Object的toString方法,使得打印出来的数据是其中的内容
  • 第二种方法中,如果字符串里面有小数和字母就会报错,只能是一个整数
  • 第三个方法中,输入的整数形式必须和进制形式吻合
  • 第四个方法中,输入的整数只能在Long的范围内,因此和第二种方法相比,取值范围更小;第四种方法在内部对常用的数字进行了优化,提前把-16 ~ 16 先创建好BigInteger的对象,如果多次获取不会重新创建新的对象,而是直接指向之前创建好的对象。

构造方法小结:
在这里插入图片描述
成员方法:
在这里插入图片描述
成员方法注意:

  • 这里都是方法,必须创建对象后调用方法才能进行运算
  • equals重写了,比较的是BigInteger对象当中的数据值不是地址值
  • intValue方法不能超出int范围

BigInteger的底层存储方式(了解,跳过)

BigDecima

用于小数的精确运算 / 用来表达很大的小数。

两个构造方法示例:

  • public Bigdecima(double val):这种方式有可能是不精确的,不建议使用
  • public Bigdecima(String val):根据传递的字符串创建小数,结果精确

**静态方法valueOf:**如果我们传递的是0~10之间的整数,包含0,包含10,那么方法会返回已经创建好的对象,不会重新new;如果传递的是是小数,那么底层返回的是帮我们new出来的Bigdecima

建议:
在这里插入图片描述
成员方法:
在这里插入图片描述
成员方法注意

  • 使用divide(BigDecima val)的时候必须保证两个数之间除得尽,如10.0和2.0,8.0和4.0等,不然会报错
  • 舍入模式是一个类RoundingMode,当中有很多静态常量供我们选择,它们表示不同的舍入模式。只需要掌握一个舍入模式HALF_UP(四舍五入),如果与两个相邻数字距离相等,则向上舍入(远离零的方向,如4.5变5,2.5变3,-2.5变-3);其他的不会查文档即可。

BigDecima的底层存储方式(跳过)

遍历输入的字符串,转换成字符数组,然后存储ASCII码表对应数字。

正则表达式

实际开发正则表达式的用法:1、下载插件,导入常用的正则表达式;2、用AI写、百度找;3、查API文档,自己写。

  • 自己写的心得:按照正确的数据,从左往右依次匹配字符

API文档中:Pattern类,只要掌握字符、字符类、预定义字符类、Greedy 数量词即可。

作用一:校验字符串是否满足规则。如校验用户名、校验密码、校验身份证等字符串。

作用二:在一段文本中查找想要的内容。

matches方法:
在这里插入图片描述
预定义字符示例:

package com.itheima.a08regexdemo;
public class RegexDemo3 {
    public static void main(String[] args) {
        // \ 转义字符 改变后面那个字符原本的含义
        //此时\表示转义字符,改变了后面那个双引号原本的含义
        //把他变成了一个普普通通的双引号而已。
        System.out.println("\"");

        // \表示转义字符
        //两个\的理解方式:前面的\是一个转义字符,改变了后面\原本的含义,把他变成一个普普通通的\而已。
        System.out.println("c:Users\\moon\\IdeaProjects\\basic-code\\myapi\\src\\com\\itheima\\a08regexdemo\\RegexDemo1.java");

        //.表示任意一个字符
        System.out.println("你".matches("..")); //false
        System.out.println("你".matches(".")); //true
        System.out.println("你a".matches(".."));//true

        // \\d 表示任意的一个数字
        // \\d只能是任意的一位数字
        // 简单来记:两个\表示一个\
        System.out.println("a".matches("\\d")); // false
        System.out.println("3".matches("\\d")); // true
        System.out.println("333".matches("\\d")); // false

        //\\w只能是一位单词字符[a-zA-Z_0-9]
        System.out.println("z".matches("\\w")); // true
        System.out.println("2".matches("\\w")); // true
        System.out.println("21".matches("\\w")); // false
        System.out.println("你".matches("\\w"));//false

        // \\W非单词字符
        System.out.println("你".matches("\\W")); // true
        System.out.println("---------------------------------------------");
        // 以上正则匹配只能校验单个字符。

        // 必须是数字 字母 下划线 至少 6位
        System.out.println("2442fsfsf".matches("\\w{6,}"));//true
        System.out.println("244f".matches("\\w{6,}"));//false

        // 必须是数字和字符 必须是4位
        System.out.println("23dF".matches("[a-zA-Z0-9]{4}"));//true
        System.out.println("23 F".matches("[a-zA-Z0-9]{4}"));//false
        System.out.println("23dF".matches("[\\w&&[^_]]{4}"));//true
        System.out.println("23_F".matches("[\\w&&[^_]]{4}"));//false
    }
}

正则表达式练习:

        //邮箱号码
        //3232323@qq.com zhangsan@itcast.cnn dlei0009@163.com dlei0009@pci.com.cn
        //思路:
        //在书写邮箱号码正则的时候需要把正确的数据分为三部分
        //第一部分:@的左边 \\w+
        //      任意的字母数字下划线,至少出现一次就可以了
        //第二部分:@ 只能出现一次
        //第三部分:
        //      3.1         .的左边[\\w&&[^_]]{2,6}
        //                  任意的字母加数字,总共出现2-6次(此时不能出现下划线)
        //      3.2         . \\.为什么是//.????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????
        //      3.3         大写字母,小写字母都可以,只能出现2-3次[a-zA-Z]{2,3}
        //      我们可以把3.2和3.3看成一组,这一组可以出现1次或者两次
        String regex3 = "\\w+@[\\w&&[^_]]{2,6}(\\.[a-zA-Z]{2,3}){1,2}";
        System.out.println("3232323@qq.com".matches(regex3));
        System.out.println("zhangsan@itcast.cnn".matches(regex3));
        System.out.println("dlei0009@163.com".matches(regex3));
        System.out.println("dlei0009@pci.com.cn".matches(regex3));
    }
}

忽略大小写

//忽略大小写的书写方式
//在匹配的时候忽略abc的大小写
String regex4 = "a((?i)b)c";
System.out.println("------------------------------");
System.out.println("abc".matches(regex4));//true
System.out.println("ABC".matches(regex4));//false
System.out.println("aBc".matches(regex4));//true

正则表达式符号总结(眼熟即可):
在这里插入图片描述

包装类

基本数据类型所对应的引用数据类型。如int->Integer。通俗来说:用对象把基本数据包起来。

内存图
在这里插入图片描述
应用场景:**

  • 方法中需要接受一个对象类型的时候,如method(Object obj),这时候基本数据类型就接收不了
  • 集合只能存储对象类型的数据

八大数据类型对应的包装类

两个特殊

获取Integer对象的方式(了解)

JDK5后对此进行了优化。JDK5前需要自己构造或者调用静态方法

  • 采用构造方法创建对象

Integer i = new Integer(1);

  • 采用静态方法创建对象

Integer i = Integer.valueOf(123);

获取Integer对象两种方式的区别(掌握)

对于valueOf静态方法,查看源码可以发现,底层帮助我们将-128~127(byte类型的取值范围)对应的对象事先创建好并存储在了数组当中,因此用==号比较地址值需要注意。

  • 应用背景:
    因为在实际开发中,-128~127之间的数据,用的比较多。
    如果每次使用都是new对象,那么太浪费内存了
    所以,提前把这个范围之内的每一个数据都创建好对象
    如果要用到了不会创建新的,而是返回已经创建好的对象。
        Integer i6 = Integer.valueOf(127);
        Integer i7 = Integer.valueOf(127);
        System.out.println(i6 == i7);//true
        
        Integer i8 = Integer.valueOf(128);
        Integer i9 = Integer.valueOf(128);
        System.out.println(i8 == i9);//false

JDK5以后包装类的新特性

自动装箱和自动拆箱(JDK5以后)

  • 自动装箱:把基本数据类型自动变成包装类。举例:
//JDK5以前,需要手动创建对象
Integer i = new Integer(1);
//或者手动调用静态方法
Integer i = Integer.valueOf(1);
//JDK5以后,自动装箱。把基本数据类型1直接赋值给包装类对象i,在底层就帮我们创建好1的包装类对象
Integer i = 1;
  • 自动拆箱:把包装类自动变成对应基本数据类型。举例:
//把包装类对象Integer i赋值给对应的基本数据类型变量int i。底层会帮我们进行拆箱,即把包装类对象转换为基本数据类型,再参与计算
int a =i;

结论:在JDK5以后,int和Integer可以看做是同一个东西,因为在内部可以自动转化。

以后不需要new创建对象,也不需要调用静态方法,直接将基本数据赋值给包装类对象即可。

对于包装类的计算,我们可以直接采用变量名参与计算即可。

Integer i1 = 1;
Integer i2 = 2;
Integer i3 = i1 +i2;
print(i3);//3

包装类Integer的成员方法

  • 应用1:得到某个整数的不同进制下的数据
    public static void main(String[] args) {
        /*
            public static string tobinarystring(int i)传入int类型的整数,得到二进制
            public static string tooctalstring(int i) 传入int类型的整数,得到八进制
            public static string toHexstring(int i) 传入int类型的整数,得到十六进制
            public static int parseInt(string s) 传入字符串,将字符串类型的整数转成int类型的整数
        */
        //1.把整数转成二进制,十六进制
        String str1 = Integer.toBinaryString(100);
        System.out.println(str1);//1100100

        //2.把整数转成八进制
        String str2 = Integer.toOctalString(100);
        System.out.println(str2);//144

        //3.把整数转成十六进制
        String str3 = Integer.toHexString(100);
        System.out.println(str3);//64

        //4.将字符串类型的整数转成int类型的整数
        //java是强类型语言:每种数据在java中都有各自的数据类型,在计算的时候,如果不是同一种数据类型,是无法直接计算的。
        int i = Integer.parseInt("123");
        System.out.println(i);
        System.out.println(i + 1);//124
        //细节1:
        //在类型转换的时候,括号中的参数只能是数字不能是其他,否则代码会报错
            //细节2:
        //8种包装类当中,除了Character都有对应的parseXxx的方法,进行类型转换
        String str = "true";
        boolean b = Boolean.parseBoolean(str);
        System.out.println(b);


    }
}
  • 应用2:用parsexxx方法改写键盘录入
public class A05_IntegerDemo5 {
    public static void main(String[] args) {
        //键盘录入
        Scanner sc = new Scanner(System.in);
        System.out.println("请输入一个字符串");
        /* String str = sc.next();
        System.out.println(str);*/
        //当我们在使用next,nextInt,nextDouble在接收数据的时候,弊端:遇到空格,回车,制表符的时候就停止了
        //键盘录入的是123 123 那么此时只能接收到空格前面的数据,而不是想要的是接收一整行数据
        //建议:以后我们如果想要键盘录入,不管什么类型,统一使用nextLine,可以接收一整行数据,特点:遇到回车才停止
        //这个接收的line是字符串类型的
        String line = sc.nextLine();
        System.out.println(line);
        //将得到的一整行数据再去调用parsexxx静态方法转成自己想要的数据类型
        //如Double.parseDouble方法,将传入的字符串类型的小数转成double类型的小数
        double v = Double.parseDouble(line);
        System.out.println(v);
    }
}

参考学习资料:https://www.bilibili.com/video/BV17F411T7Ao/?spm_id_from=333.1007.top_right_bar_window_default_collection.content.click&vd_source=b3f048c1c718e510d2f25b81161f3479

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/506936.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Spring如何进行事务管理?什么是面向切面编程?

喜欢就点击上方关注我们吧&#xff01; 本篇将带你快速了解Spring事务管理以及面向切面编程(AOP)相关知识。 一、事务 1、概述 1&#xff09;事务是一组操作的集合&#xff0c;是一个不可分割的工作单位&#xff0c;这些操作要么同时成功&#xff0c;要么同时失败。 2&#xff…

八股 -- C#

面向对象 &#xff08;三大特性&#xff09; 三大特性目的是为了提供更好的代码组织、可维护性、扩展性和重用性 C#基础——面向对象 - 知乎 (zhihu.com) 封装 理解&#xff1a; 你不需要了解这个方法里面写了什么代码&#xff0c;你只需要了解这个方法能够给你返回什么数据&…

矩阵乘法优化:GEMM中如何将大矩阵切割成小矩阵

论文自然还是 Anatomy of High-Performance Matrix Multiplication。 如何拆分 一个矩阵乘法有 6 种拆分方式&#xff0c;其中对 row-major 效率最高的是&#xff1a; 第一次拆分 先做第一次拆分&#xff0c;取 A 的 kc 列&#xff08;PanelA&#xff09;和 B 的 kc 行&…

基于 7 大城市实景数据,清华大学团队开源 GPD 模型

城市&#xff0c;是人们安居乐业的故土&#xff0c;是政府开展经济建设的基石&#xff0c;承载着细腻的人文情怀与宏伟的国家发展脉络。长期以来&#xff0c;管理者一直在探寻更加高效、科学的城市治理方法&#xff0c;解决不同地区资源供给不平衡、交通拥挤、人口流失等问题。…

Qt项目通过.pri文件将众多文件按功能模块分类显示,开发大型项目必备

Chapter1 Qt项目通过.pri文件将众多文件按功能模块分类显示&#xff0c;开发大型项目必备 Chapter2 在Qt项目中添加pri文件 原文链接&#xff1a;在Qt项目中添加pri文件_qtpri-CSDN博客 前言 一般我们创建Qt项目工程的时候&#xff0c;都是直接把所有的项目&#xff0c;头文…

Chatopera 云服务的智能问答引擎实现原理,如何融合 #聊天机器人 技术 #Chatbot #AI #NLP

观看视频 Bilibili: https://www.bilibili.com/video/BV1pZ421q7EH/YouTube: https://www.youtube.com/watch?vx0d1_0HQa8o 内容大纲 提前在浏览器打开网址&#xff1a; Chatopera 云服务&#xff1a;https://bot.chatopera.comChatopera 入门教程&#xff1a;https://dwz…

微机原理-基于8086电压报警器系统仿真设计

**单片机设计介绍&#xff0c;微机原理-基于8086电压报警器系统仿真设计 文章目录 一 概要二、功能设计设计思路 三、 软件设计原理图 五、 程序六、 文章目录 一 概要 基于8086的电压报警器系统仿真设计概要主要涉及到系统的整体架构设计、硬件组成、软件逻辑设计以及仿真环境…

【智能算法】黄金正弦算法(GSA)原理及实现

目录 1.背景2.算法原理2.1算法思想2.2算法过程 3.结果展示4.参考文献 1.背景 2017年&#xff0c;Tanyildizi等人受到正弦函数单位圆内扫描启发&#xff0c;提出了黄金正弦算法&#xff08;Golden Sine Algorithm, GSA&#xff09;。 2.算法原理 2.1算法思想 GSA来源于正弦函…

前端学习<二>CSS基础——14-CSS3属性详解:Web字体

前言 开发人员可以为自已的网页指定特殊的字体&#xff08;将指定字体提前下载到站点中&#xff09;&#xff0c;无需考虑用户电脑上是否安装了此特殊字体。从此&#xff0c;把特殊字体处理成图片的方式便成为了过去。 支持程度比较好&#xff0c;甚至 IE 低版本的浏览器也能…

C语言内存函数(超详解)

乐观学习&#xff0c;乐观生活&#xff0c;才能不断前进啊&#xff01;&#xff01;&#xff01; 我的主页&#xff1a;optimistic_chen 我的专栏&#xff1a;c语言 点击主页&#xff1a;optimistic_chen和专栏&#xff1a;c语言&#xff0c; 创作不易&#xff0c;大佬们点赞鼓…

安全用电监控系统在工厂的研究与应用论述

摘 要&#xff1a;随着社会时代的发展&#xff0c;人们的安全意识越来越强烈&#xff0c;在人们生活和工作中离不开各种用电设备&#xff0c;用电设备的安全使用是保障人们生命安全的重要内容。工厂因自身厂内工作环境的特殊性&#xff0c;用电设备的种类多且复杂&#xff0c;如…

【数据结构与算法初阶(c语言)】插入排序、希尔排序、选择排序、堆排序、冒泡排序、快速排序、归并排序、计数排序-全梳理(万字详解,干货满满,建议三连收藏)

目录 1.排序的概念及其运用 1.1排序的概念 1.2排序运用 1.3常见的排序算法 2.插入排序 2.1 原理演示&#xff1a;​编辑 2.2 算法实现 2.3 算法的时间复杂度和空间复杂度分析 3.希尔排序 3.1算法思想 3.2原理演示 3.3代码实现 3.4希尔算法的时间复杂度 4.冒泡排序 4.1冒泡排…

二、图的表示和带权图

文章目录 1、图的表示1.1 邻接矩阵1.2 邻接表1.3 关联矩阵 2、带权图2.1 最短路径问题2.2 中国邮递员问题2.3 旅行商问题 THE END 1、图的表示 1.1 邻接矩阵 \qquad 将图的所有顶点分别构成一个二维矩阵的行列&#xff0c;将顶点之间的边关系表示在构成的矩阵之中&#xff0c;…

在CentOS 8.5.2111下安装vncserver

# 参考&#xff1a; 如何在 CentOS 8/RHEL 8 上安装配置 VNC 服务器 安装CentOS 8.5.2111 及 vncserver # 标准安装步骤 安装GNOME桌面环境使用屏幕号:1。安装VNC服务器&#xff08;tigervnc-server tigervnc&#xff09;设置VNC密码设置VNC服务器配置文件开启vnc服务。开放防…

FX110网:货币交易5个亏损典型,你有中招吗?

人生百年几今日&#xff0c;今日不为真可惜&#xff01;若言姑待明朝至&#xff0c;明朝又有明朝事。很多投资朋友总是抱怨&#xff0c;为什么总是看见别人赚钱&#xff0c;自己一进场就亏损&#xff0c;那么在这里投资失败无非两点&#xff1a;一是自身原因&#xff0c;自己没…

SAP 销售分销中的免费货物

销售业务中&#xff0c;免费货物在您与客户协商价格时起着重要作用。在零售、化工或消费品这样的行业部门中&#xff0c;通常以免费货物的形式向客户提供折扣。 作为用户&#xff0c;业务用户希望能自动确定免费货物并将它们归入销售凭证中。同时需要向成本控制部门提供免费货物…

密码算法概论

基本概念 什么是密码学&#xff1f; 简单来说&#xff0c;密码学就是研究编制密码和破译密码的技术科学 例题&#xff1a; 密码学的三个阶段 古代到1949年&#xff1a;具有艺术性的科学1949到1975年&#xff1a;IBM制定了加密标准DES1976至今&#xff1a;1976年开创了公钥密…

盘点那些好用的SAP FIORI App(一) Display Customer/Supplier List

做SAP运维的人可能都知道&#xff0c;SAP标准的菜单里面基本没有好用的report可以用来批量显示并导出客户清单&#xff0c;或者供应商清单。T-code MKVZ 可以导出供应商的采购数据&#xff0c;但仅限于部分字段&#xff0c;客户清单的话系统标准的有这个S_ALR_87012179 - Custo…

电脑端手机配置检测工具推荐与使用指南

摘要 本文介绍了如何使用克魔助手工具在电脑上检测手机的配置信息。通过该工具&#xff0c;用户可以全面了解手机的硬件和操作系统信息&#xff0c;包括电池、CPU、内存、基带信息和销售信息等。 引言 在日常工作中&#xff0c;了解手机的配置信息对于开发和测试人员非常重要…

算法刷题笔记(3.25-3.29)

算法刷题笔记 3.25-3.29 1. 相同的树2. 二叉树的最近公共祖先3. 二叉搜索树中第K小的元素通过双端队列duque 中序遍历 4. 二叉树的锯齿形层序遍历new LinkedList<Integer>(levelList)双端队列复制 数组需要左右顺序&#xff0c;考虑双端队列 5. 岛屿数量6. 字典序排数&am…