当前位置: 首页 > news >正文

Java基础算法题

 以创作之名致敬节日

胜固欣然,败亦可喜。 --苏轼

目录

练习1 : 

 优化代码

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

练习2: 

方法一: 

方法二:

方法三:

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

 练习3 : 

练习4: 

练习5 :  

练习6: 

练习7 : 

练习8 : 

 练习9 : 

方法一: 

 方法二:

 练习10: 


练习1 : 

 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 自动抽取方法

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

练习2: 

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

方法一: 

分析:
        思路一 :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 + "个质数");}
}

运行结果: 

方法二:

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 + "个质数");}
}

方法三:

这里使用的一个方法

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;}
}

 练习3 : 

  

练习4: 

分析:

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

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

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

,的

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]);}}
}

运行结果: 

练习5 :  

代码实现:

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~100Scanner sc = new Scanner(System.in);for (int i = 0; i < scores.length; ) {System.out.println("请输入评委的打分");int score = sc.nextInt();//当数据瞒足要求的时候,才会 进入循环,也才会进行i++的操作,否则将是0if (score >= 0 && score <= 100) {scores[i] = score;i++;} else {System.out.println("成绩超出了范围,继续录入,当前的i为" + i);}}return scores;}
}

 结果:

  

练习6: 

扩展:

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

public class Test7 {public static void main(String[] args) {//分析://1.把整数里面的每一位放到数组当中int[] arr = {1, 9, 8, 3};//2. 加密//每位数加上5for (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);}
}

运行结果:

练习7 : 

把整数上每一位都添加到数组中
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] + " ");}}
}

运行结果:

练习8 : 

 某系统的数字密码(大于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.每一位减5for (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);}
}

运行结果: 

 练习9 : 

方法一: 

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++;}}//遍历newArrfor (int i = 0; i < newArr.length; i++) {System.out.println(newArr[i]);}}//判断prize 在数组当中是否存在//存在 true//不存在falsepublic static boolean contains(int[] arr,int prize){//prise抽到的奖项for (int i = 0; i < arr.length; i++) {if (arr[i] == prize){return true;}}return false;}
}

运行结果:

 方法二:

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

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]);}}
}

运行结果: 

 练习10: 

 

代码实现:  

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个蓝球 数组长度:7int[] 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~16while (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个蓝球 数组长度:7int[] 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;}
}

运行结果:

 

相关文章:

Java基础算法题

以创作之名致敬节日 胜固欣然&#xff0c;败亦可喜。 --苏轼 目录 练习1 : 优化代码 扩展 : CRTL Alt M 自动抽取方法 练习2: 方法一: 方法二: 方法三: Math : 顾名思义&#xff0c;Math类就是用来进行数学计算的&#xff0c;它提供了大量的静态方法来便于我们实…...

「SAP ABAP」你真的了解OPEN SQL的DML语句吗 (附超详细案例讲解)

&#x1f482;作者简介&#xff1a; THUNDER王&#xff0c;一名热爱财税和SAP ABAP编程以及热爱分享的博主。目前于江西师范大学本科在读&#xff0c;同时任汉硕云&#xff08;广东&#xff09;科技有限公司ABAP开发顾问。在学习工作中&#xff0c;我通常使用偏后端的开发语言A…...

数据结构3——线性表2:线性表的顺序结构

顺序结构的基本理解 定义&#xff1a; 把逻辑上相邻的数据元素存储在物理上相邻&#xff08;占用一片连续的存储单元&#xff0c;中间不能空出来&#xff09;的存储单元的存储结构 存储位置计算&#xff1a; LOC(a(i1))LOC(a(i))lLOC(a(i1))LOC(a(i))l LOC(a(i1))LOC(a(i))l L…...

VMware虚拟机搭建环境通用方法

目录一、前期准备1.下载并安装一个虚拟机软件二、开始创建虚拟机1.配置虚拟机硬件相关操作2.虚拟机网络相关操作三、开机配置相关内容0.开机遇到报错处理&#xff08;选看--开机没有报错请忽略&#xff09;1.开始配置2.开机之后配置3.使用xshell远程登录4.使用xshell配置虚拟机…...

2.Fully Convolutional Networks for Semantic Segmentation论文记录

欢迎访问个人网络日志&#x1f339;&#x1f339;知行空间&#x1f339;&#x1f339; 文章目录1.基础介绍2.分类网络转换成全卷积分割网络3.转置卷积进行上采样4.特征融合5.一个pytorch源码实现参考资料1.基础介绍 论文:Fully Convolutional Networks for Semantic Segmentati…...

深度解析Spring Boot自动装配原理

废话不多说了&#xff0c;直接来看源码。源码解析SpringBootApplication我们在使用idea创建好Spring Boot项目时&#xff0c;会发现在启动类上添加了SpringBootApplication注解&#xff0c;这个注解就是Spring Boot的核心所在。点击注解可以查看到到它的实现ementType.TYPE) Re…...

Redis性能分析相关-channel=[id: 0xbee27bd4, L:/127.0.0.1:63156

redis宕机...

Linux:环境变量

目录一、环境变量的理解&#xff08;1&#xff09;什么是环境变量&#xff1f;&#xff08;2&#xff09;Linux中的环境变量二、环境变量的使用&#xff08;1&#xff09;PATH环境变量&#xff08;2&#xff09;和变量相关的指令三、环境变量与普通变量的区别在平时使用电脑的时…...

Codeforces Round 703 (Div. 2)(A~D)

A. Shifting Stacks给出一个数组&#xff0c;每次可以将一个位置-1&#xff0c;右侧相邻位置1&#xff0c;判断是否可以经过若干次操作后使得数列严格递增。思路&#xff1a;对于每个位置&#xff0c;前缀和必须都大于该位置应该有的最少数字&#xff0c;即第一个位置最少是0&a…...

Django项目5——基于tensorflow serving部署深度模型——windows版本

1&#xff1a;安装docker for windows 可能需要安装WLS2&#xff0c;用于支持Linux系统&#xff0c;参照上面的教程安装 2&#xff1a;在Powershell下使用docker docker pull tensorflow/serving3&#xff1a;在Powershell下启动tensorflow serving docker run -p 8500:8500 …...

MySQL基础篇3

第一章 多表关系实战 1.1 实战1&#xff1a;省和市 方案1&#xff1a;多张表&#xff0c;一对多 方案2&#xff1a;一张表&#xff0c;自关联一对多 id1 name‘北京’ p_id null; id2 name‘昌平’ p_id1 id3 name‘大兴’ p_id1 id3 name‘上海’ p_idnull id4 name‘浦东’…...

携程 x TiDB丨应对全球业务海量数据增长,一栈式 HTAP 实现架构革新

随着新冠病毒疫情的缓解和控制&#xff0c;全球旅游业逐渐开始重新复苏。尤其在一些度假胜地&#xff0c;游客数量已经恢复到疫情前的水平。 携程作为全球领先的一站式旅行平台&#xff0c;旗下拥有携程旅行网、去哪儿网、Skyscanner 等品牌。携程旅行网向超过 9000 万会员提供…...

记一次Kafka warning排查过程

1、前因 在配合测试某个需求的时候&#xff0c;正好看到控制台打印了个报错&#xff0c;如下&#xff1a; 2023-03-06 17:05:58,565[325651ms][pool-28-thread-1][org.apache.kafka.common.utils.AppInfoParser][WARN] - Error registering AppInfo mbean javax.management.I…...

MySQL学习笔记(6.视图)

1. 视图作用 (1). 简化业务&#xff0c;将多个复杂条件&#xff0c;改为视图 (2). mysql对用户授权&#xff0c;只能控制表权限&#xff0c;通过视图可以控制用户字段权限。 (3). 可以避免基本表变更&#xff0c;影响业务。只需更改视图即可。 2. 视图&#xff08;创建&…...

java多线程与线程池-01多线程知识复习

多线程知识复习 文章目录 多线程知识复习第1章 多线程基础1.1.2 线程与进程的关系1.2 多线程启动1.2.1 线程标识1.2.2 Thread与Runnable1.2.3 run()与start()1.2.4 Thread源码分析1.3 线程状态1.3.1 NEW状态1.3.2 RUNNABLE状态1.3.3 BLOCKED状态1.3.4 WAITING状态1…...

Typescript - 将命名空间A导入另一个命名空间B作为B的子命名空间,并全局暴露命名空间B

前言 最近相统一管理 ts 中的类型声明&#xff0c;这就需要将各模块下的命名空间整合到全局的命名空间下&#xff0c;牵涉到从别的文件中引入命名空间并作为子命名空间在全局命名空间中统一暴露。 将命名空间A导入另一个命名空间B作为B的子命名空间 文件说明 assets.ts 文件中…...

Windows下实现Linux内核的Python开发(WSL2+Conda+Pycharm)

许多软件可以通过Python交互&#xff0c;但没有开发Windows版本&#xff0c;这个时候装双系统或虚拟机都很不方便&#xff0c;可以采取WSL2CondaPycharm的策略来进行基于Linux内核的Python开发。启动WSL2&#xff0c;安装Linux内核教程&#xff1a;旧版 WSL 的手动安装步骤 | M…...

新闻发布网站分析及适用场景

在当今数字时代&#xff0c;发布新闻的渠道已经不再局限于传统媒体&#xff0c;越来越多的企业、组织和个人开始使用互联网平台发布新闻稿&#xff0c;以提升品牌知名度和影响力。本文将介绍一些可以发布新闻的网站&#xff0c;并分析其特点和适用场景。一、新闻稿发布平台1.新…...

云原生时代顶流消息中间件Apache Pulsar部署实操之Pulsar IO与Pulsar SQL

文章目录Pulsar IO (Connector连接器)基础定义安装Pulsar和内置连接器连接Pulsar到Cassandra安装cassandra集群配置Cassandra接收器创建Cassandra Sink验证Cassandra Sink结果删除Cassandra Sink连接Pulsar到PostgreSQL安装PostgreSQL集群配置JDBC接收器创建JDBC Sink验证JDBC …...

Input子系统(一)启动篇

代码路径 基于AndroidS&#xff08;12.0&#xff09;代码 system/core/libutils/Threads.cppframeworks/base/services- java/com/android/server/SystemServer.java- core- java/com/android/server/input/InputManagerService.java- jni/com_android_server_input_InputMan…...

WuThreat身份安全云-TVD每日漏洞情报-2023-03-08

漏洞名称:Agilebio Lab Collector 远程命令执行 漏洞级别:高危 漏洞编号:CVE-2023-24217,CNNVD-202303-375 相关涉及:Agilebio Lab Collector 4.234 漏洞状态:EXP 参考链接:https://tvd.wuthreat.com/#/listDetail?TVD_IDTVD-2023-05536 漏洞名称:PrestaShop “Xen Forum”模…...

ABP IStringLocalizer部分场景不生效的问题

问题描述&#xff1a; 本地项目依赖注入本地化服务时候生效&#xff0c;第三方项目调用本地接口时候出现本地化失效的问题。 解决方案&#xff1a; 第三方服务封装的 GetHttp 请求的请求头中添加 语言相关信息 request.Headers.Add("accept-language", "zh-C…...

数组(四)-- LC[167] 两数之和-有序数组

1 两数之和 1.1 题目描述 题目链接&#xff1a;https://leetcode.cn/problems/two-sum/description/ 1.2 求解思路 1. 暴力枚举 最容易想到的方法是枚举数组中的每一个数 x&#xff0c;寻找数组中是否存在 target - x 参考代码 class Solution(object):def twoSum(self, n…...

Mac电脑,python+appium+安卓模拟器使用步骤

1、第一步&#xff0c;环境搭建&#xff0c;参考这位博主的文章&#xff0c;很齐全 https://blog.csdn.net/qq_44757414/article/details/128142859 我在最后一步安装appium-doctor的时候&#xff0c;提示权限不足&#xff0c;换成sudo appium-doctor即可 2、第二步&#xff0…...

Linux命令·find进阶

find是我们很常用的一个Linux命令&#xff0c;但是我们一般查找出来的并不仅仅是看看而已&#xff0c;还会有进一步的操作&#xff0c;这个时候exec的作用就显现出来了。 exec解释&#xff1a;-exec 参数后面跟的是command命令&#xff0c;它的终止是以;为结束标志的&#xff0…...

R语言ggplot2 | 用百分比格式表示数值

&#x1f4cb;文章目录Percent() 函数介绍例子1&#xff0c;在向量中格式化百分比&#xff1a;例子2&#xff0c;格式化数据框列中的百分比&#xff1a;例子3&#xff0c;格式化多个数据框列中的百分比&#xff1a;如何使用percent()函数在绘图过程展示通常在绘图时&#xff0c…...

【代码训练营】day53 | 1143.最长公共子序列 1035.不相交的线 53. 最大子序和

所用代码 java 最长公告子序列 LeetCode 1143 题目链接&#xff1a;最长公告子序列 LeetCode 1143 - 中等 思路 这个相等于上一题的不连续状态 dp[i] [j]&#xff1a;以[0, i-1]text1和以[0, j-1]text2 的最长公共子序列的长度为dp[i] [j]递推公式&#xff1a; 相同&#x…...

消息队列理解

为什么使用消息队列 使⽤消息队列主要是为了&#xff1a; 减少响应所需时间和削峰。降低系统耦合性&#xff08;解耦/提升系统可扩展性&#xff09;。 当我们不使⽤消息队列的时候&#xff0c;所有的⽤户的请求会直接落到服务器&#xff0c;然后通过数据库或者 缓存响应。假…...

【Linux内核一】在Linux系统下网口数据收发包的具体流向是什么?

在TCP/IP网络分层模型里&#xff0c;整个协议栈被分成了物理层、链路层、网络层&#xff0c;传输层和应用层。物理层对应的是网卡和网线&#xff0c;应用层对应的是我们常见的Nginx&#xff0c;FTP等等各种应用。Linux实现的是链路层、网络层和传输层这三层。 在Linux内核实现中…...

南京、西安集成电路企业和高校分布一览(附产业链主要厂商及高校名录)

前言 3月2日&#xff0c;国务院副总理刘鹤在北京调研集成电路企业发展&#xff0c;并主持召开座谈会。刘鹤指出&#xff0c;集成电路是现代化产业体系的核心枢纽&#xff0c;关系国家安全和中国式现代化进程。他表示&#xff0c;我国已形成较完整的集成电路产业链&#xff0c;也…...