Java基础算法题

news2024/10/2 10:25:30

 

目录

练习一 : 

 优化代码

扩展 : CRTL + Alt + M 自动抽取方法

练习二: 

方法1: 

方法2:

方法3:

Math : 顾名思义,Math类就是用来进行数学计算的,它提供了大量的静态方法来便于我们实现数学计算:

 练习三 :  

练习四 :  

 练习五: 

练习六 : 

练习七 : 

 练习八 : 

方法1: 

 方法2:

 练习九: 


练习一 : 

 import java.util.Scanner;
 public class Test1 {
    public static void main(String[] args) {
        //键盘录入数据
        Scanner sc = new Scanner(System.in);
        System.out.println("请输入当前机票的原价");
        int ticket = sc.nextInt();
        System.out.println("请输入当前月份");
        int month = sc.nextInt();
        System.out.println("请输入当前舱位 0头等舱 1经济舱");
        int seat = sc.nextInt();

        //2.先判断旺季 还是 淡季
        if (month >= 5 && month <= 10) {
            //旺季
            if (seat == 0) {
                ticket = (int) (ticket * 0.9);
            } else if (seat == 1) {
                ticket = (int) (ticket * 0.85);
            }else {
                System.out.println("没有这个舱位");
            }
        } else if (month >= 11 && month <= 12 || month <= 1 && month >= 4) {
            //淡季
            if (seat == 0) {
                ticket = (int) (ticket * 0.7);
            } else if (seat == 1) {
                ticket = (int) (ticket * 0.65);
            }else {
                System.out.println("没有这个舱位");
            }
        } else {
            System.out.println("键盘录入不合法");
        }
        System.out.println(ticket);
    } 
}

运行结果:  

 优化代码

分析:

    1. 我要干嘛?  根据舱位和折扣来计算最终的原价
    2. 我完成这个需要什么?  原价 舱位 头等舱的折扣 经济舱的折扣
    3. 方法的调用处是否需要继续使用该结果? 需要

import java.util.Scanner;
public class Test1 {
    public static void main(String[] args) {
        //键盘录入数据
        Scanner sc = new Scanner(System.in);
        System.out.println("请输入当前机票的原价");
        int ticket = sc.nextInt();
        System.out.println("请输入当前月份");
        int month = sc.nextInt();
        System.out.println("请输入当前舱位 0头等舱 1经济舱");
        int seat = sc.nextInt();

        //2.先判断旺季 还是 淡季
        if (month >= 5 && month <= 10) {
            //旺季 
            ticket = getArr(ticket,seat,0.9,0.85);
        } else if (month >= 11 && month <= 12 || month <= 1 && month >= 4) {
            //淡季 
            ticket = getArr(ticket,seat,0.7,0.65);
        } else {
            System.out.println("键盘录入的月份不合法");
        }
        System.out.println(ticket);
    }

    //1. 我要干嘛?  根据舱位和折扣来计算最终的原价
    //2. 我完成这个需要什么?  原价 舱位 头等舱的折扣 经济舱的折扣
    //3. 方法的调用处是否需要继续使用该结果? 需要

    public static int getArr(int ticket,int seat ,double d1,double d2){
        if (seat == 0) {
            ticket = (int) (ticket * d1);
        } else if (seat == 1) {
            ticket = (int) (ticket * d2);
        }else {
            System.out.println("没有这个舱位");
        }
        return ticket;
    }
}

扩展 : CRTL + Alt + M 自动抽取方法

选中需要抽取的代码,然后按下快捷键

练习二: 

在这道题中,下面罗列了三种方法 

方法1: 

分析:
        思路一 :2~99
        定义变量i ,赋值100
        判断i是否为质数 

第二个for循环的思路分析:

第二个for循环就是取 i 的值,然后依次去除以2,3,4....一直到i-1 求模,如果取模为0,则表示是可以除尽的,那就说明不是质数, flag = false;跳出循环,如果都不为0,则不会改变flag的值,flag是true 就是质数

public class Test3 {
    public static void main(String[] args) {
        //思路一 :2~99
        //定义变量i ,赋值100
        //判断i是否为质数

        //定义一个变量用来统计有多少个质数
        int count = 0;
        for (int i = 101; i <= 200; i++) {
            //i 表示循环里面的每一个数字
            //继续判断i是否为一个质数
            boolean flag = true;
            for (int j = 2; j < i; j++) {
                //j 表示2~99之间的每一个数字
                if (i % j == 0) {
                    flag = false;
                    break;
                }
            }
            if (flag) {
                System.out.println("当前数字" + i + "是质数");
                count++;
            }
        }
        System.out.println("一共有多少" + count + "个质数");
    }
}

运行结果: 

方法2:

public class Test3 {
    public static void main(String[] args) {
      //定义一个变量用来统计有多少个质数
        int count = 0;
        for (int i = 101; i <= 200; i++) {
            boolean isPrime  = true;
            for (int j = 2; j < i; j++) {
                if (i % j == 0) {
                    isPrime  = false;
                    break;
                }
            }
            if (isPrime ) {
                System.out.println(i);
                count++;
            }
        } System.out.println("101-200之间有" + count + "个质数");
    }
}

方法3:

这里使用的一个方法

Math : 顾名思义,Math类就是用来进行数学计算的,它提供了大量的静态方法来便于我们实现数学计算:

计算√x:
Math.sqrt(2); // 1.414...
public class Test10 {
    public static void main(String[] args) {
        int count = 0;
        for (int i = 101; i <= 200; i++) {
            if (isPrime(i)) {
                System.out.println(i + " ");
                count++;
            }
        }
        System.out.println();
        System.out.println("101-200之间共有" + count + "个素数");
    }

    //判断一个数是否为质数
    public static boolean isPrime(int n) {
        if (n <= 1) {
            return false;
        }
        for (int i = 2; i <= Math.sqrt(n); i++) {
            if (n % i == 0) {
                return false;
            }
        }
        return true;
    }
}

 练习三 :  

分析:

定义一个老数组并存储一些元素

再定义一个新数组的长度跟老数组一致

遍历老数组, 得到老数组中的每一个元素,依次存入新数组 

,的

i 表示老数组中的索引,新数组中的每一个索引

arr[i]  表示老数组中的元素

public class Test5 {
    public static void main(String[] args) {
        //分析:
        //1.定义一个老数组并存储一些元素
        int[] arr = {1,2,3,4,5};
        //2.定义一个新数组的长度跟老数组一致
        int[] newArr = new int[arr.length];
        //3.遍历老数组,得到老数组中的每一个元素,依次存入新数组中
        for (int i = 0; i < arr.length; i++) {
            //i 表示老数组中的索引,新数组中的每一个索引
            //arr[i] 表示老数组中的元素
            newArr[i] = arr[i];
        }
        for (int i = 0; i < arr.length; i++) {
            System.out.print(newArr[i]);
        }
    }
}

运行结果: 

练习四 :  

代码实现:

import java.util.Scanner;

public class Test6 {
    public static void main(String[] args) {
        //分析:
        //1.定义一个数组,用来存储6名评委的打分(1-100)
        int[] scoreArr = getScores();
        for (int i = 0; i < scoreArr.length; i++) {
            System.out.println(scoreArr[i]);
        }
        //2.求出数组中的最大值
        int max = getMax(scoreArr);

        //3. 求出数组中的最小值
        int min = getMin(scoreArr);

        //4.求出数组中的6个分数的总和
        int sum = getSum(scoreArr);
        //5, (总和-最大值-最小值)/4;
        int avg = (sum - max - min) / (scoreArr.length - 2);//这里为什么要减2,因为要减去最大值和最小值,为什么不直接写4,因为在代码中,最好不要写死,因为随时可能发生变化
        System.out.println("选手的最终得分为" + avg);
    }

    //求和
    public static int getSum(int[] scoreArr) {
        int sum = 0;
        for (int i = 0; i < scoreArr.length; i++) {
            sum = sum + scoreArr[i];
        }
        return sum;
    }

    //定义一个方法求最大值(//2.求出数组中的最大值)
    public static int getMax(int[] scoreArr) {
        int max = scoreArr[0];//必须要是数组里面的元素
        for (int i = 1; i < scoreArr.length; i++) {
            if (scoreArr[i] > max) {
                max = scoreArr[i];
            }
        }
        return max;
    }

    //3. 求出数组中的最小值
    public static int getMin(int[] scoreArr) {
        int min = scoreArr[0];//必须要是数组里面的元素
        //shift + F6 .同时更改名字所有相同
        for (int i = 1; i < scoreArr.length; i++) {
            if (scoreArr[i] < min) {
                min = scoreArr[i];
            }
        }
        return min;
    }

    //1. 我要干嘛?定义一个数组, 用来存储6名评委的打分(1-100)
    //2. 我需要什么? 都不需要
    //3. 干完这件事情,是否需要返回? 必须返回

    public static int[] getScores() {
        //定义数组
        int[] scores = new int[6];//动态数组
        //使用键盘录入的形式,输入分数:0~100
        Scanner sc = new Scanner(System.in);
        for (int i = 0; i < scores.length; ) {
            System.out.println("请输入评委的打分");
            int score = sc.nextInt();
            //当数据瞒足要求的时候,才会 进入循环,也才会进行i++的操作,否则将是0
            if (score >= 0 && score <= 100) {
                scores[i] = score;
                i++;
            } else {
                System.out.println("成绩超出了范围,继续录入,当前的i为" + i);
            }

        }
        return scores;
    }
}

 结果:

 练习五: 

扩展:

反转:定义两个指针,左边指针有一个从0开始, 右边有一个指针从最大索引开始,
        然后将两个指针所指向的数据进行交换,每次交换完左边的指针++ ,右边的指针--,
         当左边的指针比右边的指针小的时候,循环就结束

public class Test7 {
    public static void main(String[] args) {
        //分析:
        //1.把整数里面的每一位放到数组当中
        int[] arr = {1, 9, 8, 3};

        //2. 加密
        //每位数加上5
        for (int i = 0; i < arr.length; i++) {
            arr[i] = arr[i] + 5;
        }
        //每位数对10 求余
        for (int i = 0; i < arr.length; i++) {
            arr[i] = arr[i] % 10;
        }
        //将所有数字反转
        /*反转:定义两个指针,左边指针有一个从0开始, 右边有一个指针从最大索引开始,
        然后将两个指针所指向的数据进行交换,每次交换完左边的指针++ ,右边的指针--,
         当左边的指针比右边的指针小的时候,循环就结束*/
        for (int i = 0, j = arr.length - 1; i < j; i++, j--) {
            int temp = arr[i];
            arr[i] = arr[j];
            arr[j] = temp;
        }
        //3. 把数组里面的每一个数字进行拼接,变成加密后的结果
        int number = 0;
        for (int i = 0; i < arr.length; i++) {
            number = number * 10 + arr[i];
        }
        System.out.println(number);
    }
}

运行结果:

练习六 : 

把整数上每一位都添加到数组中
public class Test8 {
    public static void main(String[] args) {
        //把整数上每一位都添加到数组中
        //大于 0 的整数
        //反向推导

        //分析:
        //1. 计算数组的长度
        int number = 12345;
        //定义一个临时变量记录number的值,就是为了第三步的时候再次使用
        int temp = number;
        //定义一个变量进行统计
        int count = 0;
        while (number != 0) {
            //每一次循环就去掉右边一个数字
            number = number / 10;
            //去掉一位计数器就自增一次
            count++;
        }

        //2. 需要一个数组
        //动态 
        int[] arr = new int[count];

        //3. 把整数里面的每一位放到数组当中
        int index = arr.length - 1;
        while (temp != 0) {
            //获取 temp里面的每一位数组
            int ge = temp % 10;
            //再去掉右边的那位数字
            temp = temp / 10;
            //把当前获取到的个位添加到数组当中
            arr[index] = ge;
            index--;
        }
        //验证结果
        for (int i = 0; i < arr.length; i++) {
            System.out.print(arr[i] + " ");
        }
    }
}

运行结果:

练习七 : 

 某系统的数字密码(大于0) .比如1983 ,采用加密的方式进行传输,
 规则如下:
 每位数加上5
 再对10求余
 最后将所有数字反转
 得到一串新数
 按照以上规则进行解密
 比如:1983 加密之后变成8346 ,解密之后又变成 1983
public class Test11 {
    public static void main(String[] args) {
        //1.定义数组记录解密之后的结果
        int[] arr = {8,3,4,6};
        //2.反转
        for (int i = 0 ,j = arr.length -1;i<j; i++,j--) {
            int temp = arr[i];
            arr[i] = arr[j];
            arr[j] = temp;
        }
        //3.由于加密是通过对10取余的方式进行获取的
        //所以解密的时候就需要判断,0~4之间+10  5~9之间数字不变
        for (int i = 0; i < arr.length; i++) {
            if (arr[i] >= 0 && arr[i] <= 4){
                arr[i] = arr[i] + 10;
            }
        }
        //4.每一位减5
        for (int i = 0; i < arr.length; i++) {
            arr[i] = arr[i] - 5;
        }
        //5. 获取数组里面的每一位数字拼接成最终的结果
        int number = 0;
        for (int i = 0; i < arr.length; i++) {
           number = number * 10 + arr[i];
        }
        System.out.println(number);
    }
}

运行结果: 

 练习八 : 

下面分别列举了两种方法

方法1: 

public class Test13 {
    public static void main(String[] args) {
        //1. 定义数组表示奖池
         int[] arr = {2,588,888,1000,10000};
        //2,定义新数组用于存储抽奖的结果
        int[] newArr = new int[arr.length];
        //3,抽奖
        Random r = new Random();
        //因为有5个将项,所以这里要循环5次
        for (int i = 0; i < 5; ) {
            //获取随机索引
            int randomIndex = r.nextInt(arr.length);
            //获取奖项
            int prize = arr[randomIndex];
            //判断当前的奖项是否存在,如果存在则重新抽取,
            // 如果不存在,就表示是有效奖项
            boolean flag = contains(newArr,prize);
            if(!flag){
                //然后把当前抽取到的奖项添加到newArr中
                newArr[i] = prize;
                //添加完毕之后,移动索引
                i++;
            }
        }
        //遍历newArr
        for (int i = 0; i < newArr.length; i++) {
            System.out.println(newArr[i]);
        }
    }
    //判断prize 在数组当中是否存在
    //存在 true
    //不存在false
    public static boolean contains(int[] arr,int prize){//prise抽到的奖项
        for (int i = 0; i < arr.length; i++) {
            if (arr[i] == prize){
                return true;
            }
        }
        return false;
    }
}

运行结果:

 方法2:

效率高 ,利用 随机索引把奖池里面的所有奖项都打乱顺序

public class Test13 {
    public static void main(String[] args) {
        //把奖池里面的所有奖项都打乱顺序
        int[] arr = {2, 588, 888, 1000, 10000};
        Random r = new Random();
        for (int i = 0; i < arr.length; i++) {
            //获取随机索引
            int randomIndex = r.nextInt(arr.length);
            //拿着i跟随机索引randomIndex上的值进行交换
            int temp = arr[randomIndex];
            arr[i] = arr[randomIndex]; //每次打印都将随机的结果
            //arr[randomIndex] = arr[i];  每次打印都是相同的结果,并非随机
            arr[randomIndex] = temp;
        }
        //遍历奖池,从0 索引开始获得每一个奖项
        for (int i = 0; i < arr.length; i++) {
            System.out.println(arr[i]);
        }
    }
}

运行结果: 

 练习九: 

 

代码实现:  

import java.util.Random;
import java.util.Scanner;

public class Test14 {
    public static void main(String[] args) {
        //1.生成中奖号码
        int[] arr = createNumber();

        System.out.println("=======================");


        for (int i = 0; i < arr.length; i++) {
            System.out.print(arr[i] + " ");
        }
        System.out.println("======================");


        //2.用户输入彩票号码(红球+蓝球)
        int[] userInputArr = userInputNumber();
        //3.判断用户的中奖情况
        //红球  蓝球
        int redCount = 0;
        int blueCount = 0;

        //判断红球
        for (int i = 0; i < userInputArr.length - 1; i++) {
            int redNumber = userInputArr[i];
            for (int j = 0; j < arr.length - 1; j++) {
                if (redNumber == arr[j]) {
                    redCount++;
                    //如果找到了,那么后面是数字就没有必要比较了
                    //跳出内循环,继续判断下一个红球号码是否中奖
                    break;
                }
            }
        }
        //判断蓝球中奖
        int blueNumber = userInputArr[userInputArr.length - 1];
        if (blueNumber == arr[arr.length - 1]) {
            blueCount++;
        }

        //判断红球的个数以及蓝球的个数来判断中间情况
        if (redCount == 6 && blueCount == 1) {
            System.out.println("恭喜你,中奖1000万");
        } else if (redCount == 6 && blueCount == 0) {
            System.out.println("恭喜你,中奖500万");
        } else if (redCount == 5 && blueCount == 1) {
            System.out.println("恭喜你,中奖3000");
        } else if (redCount == 5 && blueCount == 0 || redCount == 4 && blueCount == 1) {
            System.out.println("恭喜你,中奖200");
        } else if (redCount == 4 && blueCount == 0 || redCount == 3 && blueCount == 1) {
            System.out.println("恭喜你,中奖10");
        } else if (redCount == 2 && blueCount == 1 || redCount == 1 && blueCount == 1 || redCount == 0 && blueCount == 1) {
            System.out.println("恭喜你,中奖5");
        } else {
            System.out.println("谢谢惠顾");
        }
    }

    public static int[] userInputNumber() {
        //1.创建数组用于添加用户购买的彩票号码
        // 6个红球 1个蓝球 数组长度:7
        int[] arr = new int[7];

        //2. 利用键盘录入让用户输入
        Scanner sc = new Scanner(System.in);
        //让用户输入红球号码
        for (int i = 0; i < 6; ) {
            System.out.println("请输入第一个" + (i + 1) + "个红球号码");
            int redNumber = sc.nextInt();
            //redNumber 在1~33唯一不重复
            if (redNumber >= 1 && redNumber <= 33) {
                boolean flag = contains(arr, redNumber);
                if (!flag) {
                    //不存在
                    //有效的,可以添加到数组中
                    arr[i] = redNumber;
                    i++;
                } else {
                    //存在
                    System.out.println("当前红球号码已经存在,请重新输入");
                }
            } else {
                System.out.println("当前红球号码超出范围");
            }
        }

        //让用户输入蓝球号码
        System.out.println("请输入蓝球号码");
        //1~16
        while (true) {
            int blueNumber = sc.nextInt();
            if (blueNumber >= 1 && blueNumber <= 16) {
                arr[arr.length - 1] = blueNumber;
                break;
            } else {
                System.out.println("当前蓝球号码超出范围");
            }
        }
        return arr;
    }

    public static int[] createNumber() {
        //1.创建数组用于添加中奖号码
        //一等奖  6个红球 1个蓝球 数组长度:7
        int[] arr = new int[7];

        //2. 随机生成号码并添加到数组当中
        //红球:不能重复  1 2 3 4 5 6
        //蓝球:可以跟红球重复 5

        //生成红球号码并添加到数组当中
        Random r = new Random();
        for (int i = 0; i < 6; ) {
            //获取红球号码
            int redNumber = r.nextInt(33) + 1;
            boolean flag = contains(arr, redNumber);
            if (!flag) {
                //把红球号码添加到数组当中
                arr[i] = redNumber;
                i++;
            }
        }
        //生成的蓝球号码并添加到数组当中
        int blueNumber = r.nextInt(16) + 1;
        arr[arr.length - 1] = blueNumber;
        return arr;
    }

    //用于判断数字在数组中是否存在
    public static boolean contains(int[] arr, int number) {
        for (int i = 0; i < arr.length; i++) {
            if (arr[i] == number) {
                return true;
            }
        }
        return false;
    }
}

运行结果:

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【GO】K8s 管理系统项目34[Docker方式–应用部署]

K8s 管理系统项目[Docker方式–应用部署] 1. 数据库 1.1 创建数据库目录 mkdir -p /data/mysql5.7/1.2 创建容器 docker run --name mysql -itd -h mysql-server -e MYSQL_ROOT_PASSWORDroot -v /data/mysql5.7:/var/lib/mysql -p 3306:3306 -e MYSQL_ROOT_PASSWORD123456 …

layui框架实战案例(19):layui-table模块表格综合应用(筛选查询、导入导出、群发短信、一键审核、照片展示、隐私加密)

系列文章目录 layui动态表格翻页和搜索的代码分析layui框架实战案例(3)&#xff1a;layui上传错误请求上传接口出现异常解决方案layui框架实战案例(9)&#xff1a;layPage 静态数据分页组件layui框架实战案例(10)&#xff1a;短信验证码60秒倒计时layui框架实战案例(11)&#…

《实践论》笔记及当下反思(二)

目录 笔记 1、马克思主义所说的绝对真理是什么&#xff1f; 2、客观现实世界的变化运动永远没有完结&#xff0c;人们在实践中对于真理的认识也就永远没有完结 3、改造客观世界&#xff0c;也改造自己的主观世界-——改造自己的认识能力 4、实践、认识、再实践、再认识&…

ARP报文内容详细分析

ARP报文格式如图&#xff1a; 字段1&#xff1a;ARP请求的目的以太网地址&#xff0c;全1时&#xff0c;代表广播地址。 字段2&#xff1a;发送ARP请求的以太网地址。 字段3&#xff1a;以太网帧类型表示后面的数据类型&#xff0c;ARP请求和ARP应答此字段为&#xff1a;0x0806…

SourceTree 重置提交、合并、撤销、回滚

SourceTree重置当前分支到此次提交使用场景&#xff1a;已提交未推送的修改撤销、想把某一次的错误修改全部撤销当前发布代码有bug需要切到上次提交发布版本Git中的HEAD解释# 使用最新一次提交重制暂存区git reset HEAD -- filename# 使用最新一次提交重制暂存区和工作区git re…

SpringBoot——统一功能处理

处理登陆拦截 上一片博客中讲到SpringAOP可以对页面进行拦截&#xff0c;我们可以用SpringAOP实现对登陆的拦截 但是由于拦截需要HttpSession对象&#xff0c;并且之后还需要页面重定向&#xff0c;因此在实际应用中&#xff0c;并不用SpringAOP进行登陆拦截&#xff0c;而是…

HBase---idea操作Hbase数据库并且映射到Hive

idea操作Hbase数据库并且映射到Hive 文章目录idea操作Hbase数据库并且映射到Hiveidea操作Hbase数据库环境准备启动服务创建Maven工程在测试类中编写初始化方法在测试类中编写关闭方法在测试类中编写创建命名空间方法在测试类中编写创建表方法在测试类中编写查看表结构方法在测试…

tmall.product.match.schema.get( 获取匹配产品规则 )

&#xffe5;免费必须用户授权 ISV发布商品前&#xff0c;需要先查找到产品ID&#xff0c;这个接口返回查找产品规则入参规则 公共参数 请求地址: HTTP地址 http://gw.api.taobao.com/router/rest 公共请求参数: 公共响应参数: 点击获取key和secret 请求示例 TaobaoClient …

ORACLE SQL格式化小数点

ORACLE SQL格式化小数点 select CONCAT(TO_CHAR(0.00100,‘990.999’),‘%’) as a0 , CONCAT(TO_CHAR(1100,‘990.999’),‘%’) as a1 , CONCAT(TO_CHAR(0.236100,‘990.999’),‘%’) as a2 , CONCAT(TO_CHAR(0.0200100,‘990.999’),‘%’) as a3 , CONCAT(TO_CHAR(1.0310…

状态机的Go语言实现版本

一、状态机 1. 定义 有限状态机&#xff08;Finite-state machine, FSM&#xff09;&#xff0c;简称状态机&#xff0c;是表示有限个状态以及在这些状态之间的转移和动作等行为的数学模型。 2. 组成要素 现态&#xff08;src state&#xff09;&#xff1a;事务当前所处的状…

Java程序中空指针异常的最佳实践

1、空指针问题 NullPointerException 是 Java 代码中最常见的异常&#xff0c;将其最可能出现的场景归为以下 5 种&#xff1a; 参数值是 Integer 等包装类型&#xff0c;使用时因为自动拆箱出现了空指针异常&#xff1b;字符串比较出现空指针异常&#xff1b;诸如 Concurren…

新建vite+vue3+ts项目,以及解决过程中遇到的问题

目录 一、新建vitevue3ts项目 二、解决过程中遇到的问题 解决报错&#xff1a;Module ‘“xx.vue“‘ has no default export. 解决报错&#xff1a;Error [ERR_MODULE_NOT_FOUND]: Cannot find package ‘uuid’ imported from xxx的解决 解决报错&#xff1a;[plugin:vi…

如何选择一款数据库?

1主流数据库技术介绍常见的数据库模型主要分为SQL关系型数据库和NoSQL非关系型数据库。其中关系型数据库分为传统关系数据库和大数据数据库&#xff0c;非关系型数据库分为键值存储数据库、列存储数据库、面向文档数据库、图形数据库、时序数据库、搜索引擎存储数据库及其他&am…

Java集合类

在了解Java集合类之前&#xff0c;我们必须首先了解java.util包&#xff0c;这个包提供了所有集合相关的接口和类。 集合是用来存储数据类型的一种数据结构&#xff0c;提到存储数据类型的数据结构我们最先想到的应该是数组&#xff0c;接下来我们简单回顾下Java中集合和数组的…

Xilinx ZYNQ 7000 HDMI

High-Definition Multimedia Interface (HDMI) 参考xilinx application note XAPP460 HDMI来自High-Definition Multimedia Interface 高分辨率多媒体接口&#xff0c;多媒体一般包含图像和声音。 Transition Minimized Differential Signaling (TMDS) 是HDMI的物理层。 TMDS…

春招冲刺(十一):前端面试之网络总结

网络总结 Q1: GET和POST的请求的区别 应用场景&#xff1a;Get是一个幂等请求&#xff0c;一般用于请求资源。post不是幂等请求&#xff0c;一般用于修改资源。缓存&#xff1a;Get请求一般缓存&#xff0c;Post一般不缓存报文格式&#xff1a;Get请求体一般为空&#xff0c;…

【Linux】linux | 修改dns | 修改网卡dns

一、说明1、业务需要&#xff0c;需要修改服务的dns的地址2、改成阿里的二、操作查询需要修改dns的网卡ifconfig说明1&#xff1a; 留意ens192&#xff0c;即网卡名称查看网卡配置文件信息cd /etc/sysconfig/network-scripts ll备份cp /etc/sysconfig/network-scripts/ifcfg-en…

Advantest爱德万直流电源维修电压电流发生器ADCMT系列

Advantest爱德万电源维修常见型号&#xff1a;ADCMT6240A/B&#xff1b;R6243/R6246&#xff1b;ADCMT系列。 维修品牌&#xff1a; 安捷伦Agilent/HP、泰克Tektronix、安立Anritsu、罗德施瓦茨、爱德万Advantest、艾法斯/马可尼IFR/Marconi、吉时利Keithley、日立Hitachi、 松…

【BOOST C++】组件编程(2)-- 组件的设计原理

GitHub - ros2/demos at foxy 一、说明 为了研究ROS2的组件编程&#xff0c;首先要理解如何何为组件。组件本是微软的发明物体&#xff0c;但是在ubuntu上需要自己从底层实现&#xff0c;就说ROS2不用你写&#xff0c;但是就能看明白也是需要一点理论功底的。本篇按照COM内幕的…

【2223sW3】LOG1

写在前面 好好学习&#xff0c;走出宿舍&#xff0c;走向毕设&#xff01; 一些心路历程记录&#xff0c;很少有代码出现 因为鬼知道哪条代码到时候变成毕设的一部分了咧&#xff0c;还是不要给自己的查重挖坑罢了 23.3.6 lammps代码修改 因为学姐要中期答辩了&#xff0c;…