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

牛客网字节面试算法刷题记录

NC78 反转链表

public ListNode ReverseList (ListNode head) {if(head==null) return head;ListNode p=head.next,q,tail=head;tail.next = null;while(p!=null){q = p.next;p.next = tail;tail = p;p = q;}return tail;}

NC140 排序

冒泡排序

public int[] MySort (int[] arr) {for(int i=0;i<arr.length-1;i++){for(int j=0;j<arr.length-i-1;j++){int temp = arr[j];if(arr[j]>arr[j+1]){arr[j] = arr[j+1];arr[j+1] = temp;}}}return arr;}

快排

public int[] MySort (int[] arr) {quickSort(arr, 0, arr.length - 1);return arr;}public void quickSort(int[] arr, int low, int high) {if (low >= high) {return;}int base = findBase(arr, low, high);quickSort(arr, low, base - 1);quickSort(arr, base + 1, high);}public int findBase(int[] arr, int low, int high) {int base = arr[low];int start = low;int end = high;while (low < high) {while (low < high && arr[high] > base) {high--;}while (low < high && arr[low] <= base) {low++;}if (low < high) {int temp = arr[low];arr[low] = arr[high];arr[high] = temp;}}arr[start] = arr[high];arr[high] = base;return high;}

NC93 设计LRU缓存结构

初始简单思路:每次放新值、取某个值时候,都把它放队列最后面,这样就能把最久未用的挤到队头,这样可以保证每次超过队列容量时,删除值和放新值时间复杂度都是O(1),因此选用一个双端队列。

进一步细化:每次set一个重复值或是get一个值时,都需要将原来的某个节点给他移动到队尾,我们都知道如果是数组类型的话,这个时间复杂度是O(n-i),如何保证这个时间复杂度也是O(1)呢。因此可以使用循环链表保存前序指针和后继指针,为了方便在队首和队尾插入元素,需要两个指针来指明队首和队尾。如何判断这个值存在不存在,肯定要hashmap了,就需要把每次新产生的节点存到hashmap里面,所以需要自己定义一个类型,hashmap key为key,值为自己定义的这个类型。

还需要一个值表明容量剩余。

那么详细来说思路就是:

set函数:1.首先要判断这个key是否已经存在,如果已经存在,那么将map里的值替换掉,并将该key对应的节点从原来位置删掉,再把该节点插入到队尾。

删除逻辑又分成三种:(1)如果是普通节点,就让node.pre.next=node.next,node.next.pre=node.pre,node.pre=null,node.next=null(2)如果该节点本身就是尾节点,说明不需要移动、不做处理;(3)如果是头结点,那么node.pre就是null,如果采用上面的逻辑就会出现空指针异常,此时只能让head=node.next  node.next.pre=null node.next=null。

2.如果不存在,也分为两种情况:(1)队伍满了,需要删除队首,并将该值从hashmap删除,再生成新节点插入队尾,容量不变,仍然为0。(2)队伍还有位置,直接生成新节点插入队尾,容量减1。两种逻辑都不要忘记将新节点的key、value存入到hashmap。

get函数:1.如果存在,找到该节点,将对应节点从原来位置删除,再将该节点插入队尾。(和set部分逻辑一样,可以考虑将删除节点、将某个节点插入到队尾这两段逻辑单独拎出来作为两个函数) 2.如果不存在,返回-1。

import java.util.*;public class Solution {
//标志队首Node head;
//标志队尾Node tail;class Node {public int key;public int value;public Node pre;public Node next;public Node(int key, int value, Node pre, Node next) {this.value = value;this.key = key;this.pre = pre;this.next = next;}}HashMap<Integer, Node> map = new HashMap<>();int count = 0;int maxCap = 0;public Solution(int capacity) {maxCap = capacity;}public void print(Node n) {Node p = n;while (p != null) {System.out.print("-" + p.value);p = p.next;}System.out.println();}public int get(int key) {
//如果存在该元素,将该元素节点移动到队尾,原位置删除if (map.containsKey(key)) {Node delNode = map.get(key);Node preNode = delNode.pre;Node nextNode = delNode.next;//在原位置删除该元素//该元素本来就是队尾,直接返回无需换位置if (count == 1 || nextNode == null) return delNode.value;//如果原来是队首,删除逻辑单独处理if (preNode == null) {head = nextNode;nextNode.pre = null;delNode.next = null;} else {preNode.next = delNode.next;delNode.next.pre = preNode;}//将元素加到队尾tail.next = delNode;delNode.next = null;delNode.pre = tail;tail = delNode;// System.out.println("----get:-----");// print(head);// map.forEach((k, v)->System.out.println("k:" + k + "v:" + v.value));// System.out.println("输出:" + delNode.value);return delNode.value;} else {//如果不存在返回-1// System.out.println("----get:-----");// print(head);// map.forEach((k, v)->System.out.println("k:" + k + "v:" + v.value));// System.out.println("输出:-1");return -1;}}public void set(int key, int value) {//插入时判断是否已经有该key,有的话需要替换,并将该元素移到队尾if (map.containsKey(key)) {Node dulNode = map.get(key);dulNode.value = value;map.put(key, dulNode);//在原位置删除该元素//该元素本来就是队尾,直接返回无需换位置if (count == 1 || dulNode.next == null) return;//如果原来是队首,删除逻辑单独处理if (dulNode.pre == null) {head = dulNode.next;dulNode.next.pre = null;dulNode.next = null;} else {dulNode.pre.next = dulNode.next;dulNode.next.pre = dulNode.pre;}//将元素加到队尾tail.next = dulNode;dulNode.next = null;dulNode.pre = tail;tail = dulNode;// System.out.println("----set:-----");// print(head);// map.forEach((k, v)->System.out.println("k:" + k + "v:" + v.value));// System.out.println("输出:null");} else {// 插入时判断数量+1是否大于容量if (maxCap <= 0) return;if (count + 1 > maxCap) {//大于容量队首元素出队map.remove(head.key);Node tempNode = head.next;head.next = null;head = tempNode;head.pre = null;count--;}//新元素入队尾Node newNode = new Node(key, value, null, null);newNode.pre = tail;if (tail != null) {tail.next = newNode;} else {tail = newNode;head = newNode;head.pre = null;tail.pre = null;head.next = null;tail.next = null;}tail = newNode;count++;map.put(key, newNode);// System.out.println("----set:-----");// print(head);// map.forEach((k, v)->System.out.println("k:" + k + "v:" + v.value));// System.out.println("输出:null");}}
}/*** Your Solution object will be instantiated and called as such:* Solution solution = new Solution(capacity);* int output = solution.get(key);* solution.set(key,value);*/

NC102 在二叉树中找到两个节点的最近公共祖先

 public int lowestCommonAncestor (TreeNode root, int o1, int o2) {HashMap<Integer,Integer> hashMap = new HashMap<>();List<TreeNode> list = new ArrayList<>();list.add(root);hashMap.put(root.val,null);while(!list.isEmpty()){TreeNode node = list.get(0);if(node.left!=null){list.add(node.left);hashMap.put(node.left.val,node.val);}if(node.right!=null){list.add(node.right);hashMap.put(node.right.val,node.val);} list.remove(0);}List<Integer> pathO1 = new ArrayList<>();pathO1.add(o1);List<Integer> pathO2 = new ArrayList<>();pathO2.add(o2);findPath(hashMap,o1,pathO1);findPath(hashMap,o2,pathO2);pathO1.forEach(p->System.out.print(p+" "));System.out.println();pathO2.forEach(p->System.out.print(p+" "));int index1=pathO1.size()-1;int index2=pathO2.size()-1;while(index1>=0 && index2>=0 && pathO1.get(index1).equals(pathO2.get(index2))){index1--;index2--;}if(index1>=0 && index2>=0){return pathO1.get(index1+1);}if(index1<0){return pathO1.get(0);}if(index2<0){return pathO2.get(0);}return 0;}public void findPath(HashMap<Integer,Integer> hashMap,Integer o,List<Integer> list){while(o!=null){if(hashMap.get(o)!=null)list.add(hashMap.get(o));o = hashMap.get(o);}}

NC19 连续子数组的最大和

描述

输入一个长度为n的整型数组array,数组中的一个或连续多个整数组成一个子数组,子数组最小长度为1。求所有子数组的和的最大值。

数据范围:

1<=n<=2×105

−100<=a[i]<=100

要求:时间复杂度为O(n),空间复杂度为 O(n)

进阶:时间复杂度为 O(n),空间复杂度为 O(1)

输入[1,-2,3,10,-4,7,2,-5],返回值:18,经分析可知,输入数组的子数组[3,10,-4,7,2]可以求得最大和为18

思路

用一个动态规划数组,每个位置上的人都有两种选择,加入前面的或者不加入,每个位置上的人努力做到自己这和最大,所以会比对上一位的和加上自己的比自己本身手里的大吗,如果打不过就加入,如果加入还不如自己单干就不加入,全程将最大值记录下来,最后就可以得到最优解。

 public int FindGreatestSumOfSubArray (int[] array) {int[] dp = new int[array.length];dp[0] = array[0];int max = dp[0];for(int i=1;i<array.length;i++){dp[i] = Math.max(dp[i-1]+array[i],array[i]);if(dp[i]>max) max = dp[i];}return max;}

NC1 大数加法

这道题注意别超时,不要切割字符串转成int数组,不要用string保存结果再反转,用一个char数组保存。

 public String solve (String s, String t) {if (s.length() <= 0)return t;if (t.length() <= 0)return s;char[] res = new char[Math.max(s.length(),t.length())];int high = 0;int index1 = s.length() - 1;int index2 = t.length() - 1;while (index1 >= 0 && index2 >= 0) {int add = s.charAt(index1) - '0' + t.charAt(index2) - '0' + high;res[index2] = (char)( add % 10 + '0');if (add >= 10) high = 1;else high = 0;index1--;index2--;}while (index1 >= 0) {int add =  s.charAt(index1) - '0' + high;res[index1] = (char)( add % 10 + '0');if (add >= 10) high = 1;else high = 0;index1--;}while (index2 >= 0) {int add = t.charAt(index2) - '0' + high;res[index2] = (char)( add % 10 + '0');if (add >= 10) high = 1;else high = 0;index2--;}String result = String.valueOf(res);if (high == 1) result = "1" + result;return result;}

NC41 最长无重复子数组

这题直接暴力法,第一层遍历用i从头到尾,第二层遍历用index从i到尾,如果遍历过程中遇到的map里没有就length加一,加入map,如果遇到重复的,比较length是否大于max,大于则替换,将mao清空,break退出此次。

public int maxLength (int[] arr) {int max = -1;int length = 0;HashMap<Integer, Boolean> hashMap = new HashMap<>();for (int i = 0; i < arr.length; i++) {for (int index = i; index < arr.length; index++) {if (!hashMap.containsKey(arr[index])) {hashMap.put(arr[index], true);length++;if (length > max) max = length;} else {hashMap.clear();length = 0;break;}}}return max;}

NC38 螺旋矩阵

描述

给定一个m x n大小的矩阵(m行,n列),按螺旋的顺序返回矩阵中的所有元素。

数据范围:0≤n,m≤10,矩阵中任意元素都满足 0∣val∣≤100

要求:空间复杂度 O(nm) ,时间复杂度 O(nm)

输入 [[1,2,3],[4,5,6],[7,8,9]]    输出 [1,2,3,6,9,8,7,4,5]

思路

递归函数,设置上top下down左left右right四个值作为四个方向的边界,先从左向右输出(j=left,j<right避免和下一个方向的输出重复),再从上往下输出(i=top,i<down),从右往左输出(j=right,j>left),从下往上输出(i=down,i>top),然后将top++,down--,left++,right--传入递归

递归出口为left>right或者top>down

需要处理的一个特殊情况是当left==right或者top==down时说明是单列、单行,此时要将此列、行单独输出后返回。

代码

 public ArrayList<Integer> spiralOrder (int[][] matrix) {int m = matrix.length;ArrayList<Integer> res = new ArrayList<>();if(m==0) return res;int n = matrix[0].length;circle(matrix, 0, n-1, 0, m-1, res);return res;}public void circle(int[][] matrix, int left, int right, int top, int down,ArrayList<Integer> res) {if(left>right || top>down) return;if(left==right){//只有一列按列遍历for(int i=top;i<=down;i++){res.add(matrix[i][left]);}return;}if(top==down){//只有一行按行遍历for(int j=left;j<=right;j++){res.add(matrix[down][j]);}return;}for(int j=left;j<right;j++){res.add(matrix[top][j]);}for(int i=top;i<down;i++){res.add(matrix[i][right]);}for(int j=right;j>left;j--){res.add(matrix[down][j]);}for(int i=down;i>top;i--){res.add(matrix[i][left]);}circle(matrix,left+1,right-1,top+1,down-1,res);}

NC17 最长回文子串

描述

对于长度为n的一个字符串A(仅包含数字,大小写英文字母),请设计一个高效算法,计算其中最长回文子串的长度。

数据范围: 1≤n≤1000

要求:空间复杂度 O(1),时间复杂度 O(n2)

进阶:  空间复杂度O(n),时间复杂度 O(n)

思路

暴力:i遍历字符串,index遍历从i到字符串尾,对每个子串s.subString(i,index+1),如果是回文串,记录长度,如果大于最大值覆盖。

另外需要一个判断是否为回文串的函数。

时间复杂度为O(N^2)+O(n)

代码

ublic int getLongestPalindrome (String A) {int maxLength = 1;int length = 1;for (int i = 0; i < A.length(); i++) {int index = i;length = 1;for (; index < A.length(); index++) {if (isPalindrome(A.substring(i, index+1))) {length = A.substring(i, index+1).length();if (length > maxLength) {maxLength = length;}}}}return maxLength;}public boolean isPalindrome(String A) {int length = A.length();Stack<Character> stack = new Stack<>();for (int i = 0; i < length; i++) {if (length % 2 != 0) {if (i < length / 2) {stack.add(A.charAt(i));} else if (i > length / 2) {if (stack.isEmpty() || !stack.pop().equals(A.charAt(i))) {return false;}}} else {if (i < length / 2) {stack.add(A.charAt(i));} else if (i >= length / 2) {if (stack.isEmpty() || !stack.pop().equals(A.charAt(i))) {return false;}}}}if (!stack.isEmpty()) return false;return true;}

NC54 三数之和

描述

给出一个有n个元素的数组S,S中是否有元素a,b,c满足a+b+c=0?找出数组S中所有满足条件的三元组。

数据范围:0≤n≤1000,数组中各个元素值满足 ∣val∣≤100

空间复杂度:O(n2),时间复杂度 O(n2)

注意:

  1. 三元组(a、b、c)中的元素必须按非降序排列。(即a≤b≤c)
  2. 解集中不能包含重复的三元组。
例如,给定的数组 S = {-10 0 10 20 -10 -40},解集为(-10, -10, 20),(-10, 0, 10) 

思路

先将数组排序(时间复杂度O(logn)),用i遍历数组。对每一个i进行循环:i右侧的第一个元素下标赋值给low,最后一个元素下标赋值给high,如果low和high所在位置数字相加等于-arr[i]将这三个元素加入到结果,同时low++,high--来继续寻找,如果小于则low++,如果大于则high--。该循环结束条件应为low不超过右边界(长度-1),high不超过左边界(0),且low<high。

除此之外要考虑去重的问题,可能有两种情况出现重复,

第一种是元素重复被选中:假设输入为[-40,-10,-10,0,10,20]的情况下,如果i遍历到第一个-10,下面去遍历会找到[-10,20][0,10],等到i遍历到第二个-10一样会得到相同的结果,这样就会产生重复。对这种重复的解决办法是,如果arr[i]==arr[i-1]就跳过(所以i需要从1开始)

第二种是进行双指针查找的区间里出现重复值:假设输入为[-10,-10,0,0,10,],i遍历到-10,找到[0,10],[0,10]两个重复。对这种的处理方式是如果arr[low]==arr[low-1]则跳过arr[low],如果arr[high]==arr[high+1]则跳过arr[high]。

为了防止数据越界,此处需要限制high<=arr.length-1,本来也应该限制low>=0,但是low的左边界是i不是0,所以此处应该是限制low>i+1(如果low取i+1,那么也会将arr[i]和arr[i+1]进行比较,arr[i]是我们选中的数,他允许和查找范围内的重复,所以显然不能取此值)

代码

public ArrayList<ArrayList<Integer>> threeSum (int[] num) {//先排序Arrays.sort(num);ArrayList<ArrayList<Integer>> result = new ArrayList<ArrayList<Integer>>();for (int i = 0; i < num.length; i++) {if (i >= 1 && num[i] == num[i - 1]) {continue;}int low = i + 1;int high = num.length - 1;while (low <= num.length - 1 && high >= 1 && low < high) {if (low > i+1 && num[low] == num[low - 1]) {low++;continue;}if (high + 1 <= num.length - 1 && num[high] == num[high + 1]) {high--;continue;}if (num[low] + num[high] == 0 - num[i]) {ArrayList<Integer> tempList = new ArrayList<Integer>();tempList.add(num[i]);tempList.add(num[low]);tempList.add(num[high]);result.add(new ArrayList<Integer>(tempList));low++;high--;} else if (num[low] + num[high] < 0 - num[i]) {low++;} else {high--;}}}return result;}

NC32 求平方根

描述

实现函数 int sqrt(int x).

计算并返回 x 的平方根(向下取整)

数据范围: 0<=x<231−1

要求:空间复杂度 O(1),时间复杂度 O(logx)

代码

public int sqrt (int x) {int low = 1;int high = x;if (x == 1) return 1;while (low <= high) {int mid = (low + high) / 2;if (x / mid >= mid && x / (mid + 1) <= mid) {return mid;} else if (x / mid >= mid) {low = mid + 1;} else {high = mid - 1;}}return 0;}

相关文章:

牛客网字节面试算法刷题记录

NC78 反转链表 public ListNode ReverseList (ListNode head) {if(headnull) return head;ListNode phead.next,q,tailhead;tail.next null;while(p!null){q p.next;p.next tail;tail p;p q;}return tail;} NC140 排序 冒泡排序 public int[] MySort (int[] arr) {for…...

QT连接Sqlite

使用QTCreator&#xff1b; 根据资料&#xff0c;Qt自带SQLite数据库&#xff0c;不需要再单独安装&#xff0c;默认情况下&#xff0c;使用SQLite版本3&#xff0c;驱动程序为***QSQLITE***&#xff1b; 首先创建项目&#xff1b;在 Build system 中应选中qmake&#xff0c;…...

ChatGPT AIGC 完成各省份销售动态可视化分析

像这样的动态可视化由人工智能ChatGPT AIGC结合前端可视化技术就可以实现。 Prompt:请使用HTML,JS,Echarts 做一个可视化分析的案例,地图可视化,数据可以随机生成,请写出完整的代码 完整代码复制如下: <!DOCTYPE html> <html> <head><meta char…...

基于SpringBoot+Vue的餐饮管理系统设计与实现

前言 &#x1f497;博主介绍&#xff1a;✌全网粉丝10W,CSDN特邀作者、博客专家、CSDN新星计划导师、全栈领域优质创作者&#xff0c;博客之星、掘金/华为云/阿里云/InfoQ等平台优质作者、专注于Java、小程序技术领域和毕业项目实战✌&#x1f497; &#x1f447;&#x1f3fb;…...

2023 亲测好用版VScode配置文件

tasks.json {"tasks": [{"type": "cppbuild","label": "g++",// 调试会话开始前执行的任务,一般为编译程序,c++为g++, c为gcc 和launch中preLaunchTask保持一致// "command": "D:/Users/Downloads/ming…...

jmeter基础压力教程

Jmeter基础压力测试教程 一、安装Jmeter&#xff1b; 安装需求&#xff1a;1. JDK 8.0.91安装包&#xff08;最新即可&#xff0c;配置环境变量&#xff09; 2. Badboy2.25脚本录制工具&#xff08;注&#xff1a;Jmeter3.0与badboy2.0不兼容&#xff09; Jmerter安装包…...

图片格式大全

青春不能回头&#xff0c;青春也没有终点。 大全介绍 图片格式有多种&#xff0c;每种格式都有其独特的特性和用途。以下是一些常见的图片格式以及它们的介绍&#xff1a; JPEG&#xff08;Joint Photographic Experts Group&#xff09;&#xff1a; 文件扩展名&#xff1a;…...

5.14.1.2 Get Log Page – Smart Log

SMART / Health Information (Log Identifier 02h) smart log 可通过nvme cli获取如下: 同样也可以通过get-log 命令获取到原始数据如下: 此日志页用于提供SMART和常用的helath 信息。所提供的信息在控制器的使用寿命内,并在整个power cycle前后都保留。要访问控制器日志…...

【深度学习实验】线性模型(一):使用NumPy实现简单线性模型:搭建、构造损失函数、计算损失值

#【中秋征文】程序人生&#xff0c;中秋共享# 目录 一、实验介绍 二、实验环境 1. 配置虚拟环境 2. 库版本介绍 三、实验内容 0. 导入库 1. 定义线性模型linear_model 2. 定义损失函数loss_function 3. 定义数据 4. 调用函数 一、实验介绍 使用Numpy实现 线性模型搭…...

springcloud3 分布式事务-seata的四种模式总结以及异地容灾

一 seata四种模式比较 1.1 seata的4种模式比较 二 seata的高可用 2.1架构 1.建TC服务集群非常简单&#xff0c;启动多个TC服务&#xff0c;注册到nacos即可。 2.做异地多机房容灾&#xff0c;比如一个TC集群在上海&#xff0c;另一个TC集群在杭州&#xff0c; 3.微服务基…...

【办公类-16-06】20230901大班运动场地分配表-斜线排列、5天循环、不跳节日,手动修改节日”(python 排班表系列)

背景需求&#xff1a; 大班组长发来一个“运动排班”的需求表&#xff1a;“就是和去年一样的每个班的运动排班&#xff0c;就因为今年大班变成7个班&#xff0c;删掉一个场地&#xff0c;就要重新做一份&#xff0c;不然我就用去年的那份了&#xff08;8个大班排班&#xff0…...

java学习--day13 (static关键字、异常)

文章目录 day12复习今天的内容1.static关键字【重点】1.1生活的角度来理解静态的资源1.2Java中的静态1.2.1static修饰成员变量1.2.2static修饰成员方法1.2.3static修饰代码块 2.异常2.1生活中的异常2.2Java中的异常2.3Throwable类2.4错误和异常2.5异常【重点】2.5.1异常的捕捉2…...

英飞凌TC3xx--深度手撕HSM安全启动(五)--TC3xx HSM启动流程、通信机制分析

在包含HSM的MCU的软件开发里,Host和Hsm应该为两个独立的软件工程。不管是Etas还是Vector的HSM包,都是需要单独收费的。 既然是单独的工程,相应的启动代码也是必须要有的。 在英飞凌的HSM固件架构里,HSM BootRom主要有以下几个作用:内部测试、生产使用、启动配置等。那么接…...

【窗体】Winform两个窗体之间通过委托事件进行值传递,基础篇

2023年&#xff0c;第38周。给自己一个目标&#xff0c;然后坚持总会有收货&#xff0c;不信你试试&#xff01; 在实际项目中&#xff0c;我们可能会用到一些窗体做一些小工具或者小功能。比如&#xff1a;运行程序&#xff0c;在主窗体A基础上&#xff0c;点击某个按钮希望能…...

mac使用指南

新公司给配备了mac&#xff0c;可惜土鳖的我不会用&#xff0c;所以特地写了一篇文章记录学习mac的过程 快捷键 删除&#xff1a;commanddelete 光标移至最右/左&#xff1a;command右/左箭头 截图&#xff1a;commandshift3/4/5&#xff0c;3代表截全屏&#xff0c;4代表选…...

Git 版本控制系统 笔记

概念&#xff1a;一个免费开源&#xff0c;分布式的代码版本控制系统&#xff0c;帮助开发团队维护代码 作用&#xff1a;记录代码内容&#xff0c;切换代码版本&#xff0c;多人开发时高效合并代码内容【团队开发同一个项目的代码版本管理】 1、Git 安装 之前写了&#xff0…...

VRTK4⭐四.和 UI 元素交互

文章目录 &#x1f7e5; 安装Tilia Unity.UI&#x1f7e7; 配置射线与UI交互器1️⃣ 配置直线射线2️⃣ 配置UI交互器 &#x1f7e8; 配置UI1️⃣ 更新EventSystem2️⃣ 进行Canvas设置 我们要实现的功能: 右手触摸到圆盘:显示直线射线 右手圆盘键按下:与选中UI交互 &#x1f7…...

【STM32】SDIO—SD 卡读写01

基于stm32f103 基于零死角玩转STM32—F103指南者 简介 1.SD 卡总共有 8 个寄存器&#xff0c;用于设定或表示 SD 卡信息。 2.SD卡的寄存器不能像STM32那样访问&#xff0c;而是利用命令访问&#xff0c;SDIO 定义了 64 个命令。SD 卡接收到命令后&#xff0c;根据命令要求对…...

SpringCloud Alibaba 整合Sentinel的基本使用

文章目录 一、什么是Sentinel二、Sentinel 的主要特性1. 流量控制&#xff1a;2. 熔断降级&#xff1a;3. 实时监控&#xff1a;4. 规则配置&#xff1a;5. 集成方便&#xff1a; 三、Sentinel 分为哪几部分:1. 核心库&#xff08;Java 客户端&#xff09;2. 控制台&#xff08…...

Linux中如何执行命令

目录 命令格式&#xff1a; 命令分类&#xff1a; 命令帮助&#xff1a; 1、man 2、help 3、--help 4、info命令 终止命令&#xff1a; 补全命令&#xff1a; 1&#xff09;补全命令&#xff1a; 2&#xff09;补全文件名和目录名&#xff1a; 命令格式&#xff1a;…...

基于51单片机的智能病房呼叫系统的设计与实现

一、前言 显示床位号使用到4位数码管&#xff0c;为了节约单片IO口&#xff0c;使用TM1637来驱动数码管。 二、TM1637驱动芯片简介 三、电路设计&#xff0c;使用矩阵按键来模拟每个床位的呼叫按钮 四、编写51单片机代码 void delay_ms(u16 n) {u8 i;while(n--){i 111;while…...

js在一个时间范围内产生一个随机时间

js使用使用到Math.random()方法实现在一个时间范围内产生一个随机时间。 /*在时间范围内产生一个随机时间*/ function randomDate(start, end) {if (start ! null && end ! null) {const _start new Date(start).getTime();const _end new Date(end).getTime();cons…...

Javascript Date 对象相关知识

Javascript Date 对象相关知识 参考文章虹猫1992 创建 Date 对象. 方法一: 自动使用当前的日期和时间作为其初始值. var date new Date();方法二:将给定的毫秒数转换为使用的时间&#xff0c;new Date(dateVal) 如果是数字值&#xff0c;dateVal表示指定日期与1970年1月1日午…...

Vim快捷用法

以下为文本操作 1.快速切换 行首^(shift4) 行尾$(shift6) 文章开始gg 位置末尾G 向下翻页CTRLB 向上翻页CTRLF 2.删除内容 删除一行 dd 3.复制粘贴 复制一行yy 粘贴 p 4.撤销操作 撤销操作 u 恢复操作ctrlr 以下都为底行操作 1.显示行号 set nu 2.多文件分屏阅读 加入阅…...

Stream流的常用方法(自用)

自用的笔记, 有&#x1f6a9; 需要多看 基本数据 自定义实体 Data class Student{private String name;private Integer age;private Double height;public Student() {} }假数据 Student s1 new Student(); s1.setAge(20); s1.setName("cookie"); s1.setHeight(…...

【python函数】torch.nn.Embedding函数用法图解

学习SAM模型的时候&#xff0c;第一次看见了nn.Embedding函数&#xff0c;以前接触CV比较多&#xff0c;很少学习词嵌入方面的&#xff0c;找了一些资料一开始也不是很理解&#xff0c;多看了两遍后&#xff0c;突然顿悟&#xff0c;特此记录。 SAM中PromptEncoder中运用nn.Emb…...

with ldid... /opt/MonkeyDev/bin/md: line 326: ldid: command not found

吐槽傻逼xcode 根据提示 执行了这个脚本/opt/MonkeyDev/bin/md 往这里面添加你brew install 安装文件的目录即可...

[golang gui]fyne框架代码示例

1、下载GO Go语言中文网 golang安装包 - 阿里镜像站(镜像站使用方法&#xff1a;查找最新非rc版本的golang安装包) golang安装包 - 中科大镜像站 go二进制文件下载 - 南京大学开源镜像站 Go语言官网(Google中国) Go语言官网(Go团队) 截至目前&#xff08;2023年9月17日&#x…...

2000-2018年各省能源消费和碳排放数据

2000-2018年各省能源消费和碳排放数据 1、时间&#xff1a;2000-2018年 2、范围&#xff1a;30个省市 3、指标&#xff1a;id、year、ENERGY、COAL、碳排放倒数*100 4、来源&#xff1a;能源年鉴 5、指标解释&#xff1a; 2018年碳排放和能源数据为插值法推算得到 碳排放…...

C# ref 学习1

ref 关键字用在四种不同的上下文中&#xff1b; 1.在方法签名和方法调用中&#xff0c;按引用将参数传递给方法。 2.在方法签名中&#xff0c;按引用将值返回给调用方。 3.在成员正文中&#xff0c;指示引用返回值是否作为调用方欲修改的引用被存储在本地&#xff0c;或在一般…...

昆山苏州网站建设/免费发布产品信息的网站

网易考拉&#xff08;以下简称考拉&#xff09;是网易旗下以跨境业务为主的综合型电商&#xff0c;自2015年1月9日上线公测后&#xff0c;业务保持了高速增长&#xff0c;这背后离不开其技术团队的支撑。微服务化是电商IT架构演化的必然趋势&#xff0c;网易考拉的服务架构演进…...

建设银行 网站设置密码/合肥seo报价

1. 水平居中设置-行内元素 我们在实际工作中常会遇到需要设置水平居中的场景&#xff0c;比如为了美观&#xff0c;文章的标题一般都是水平居中显示的。 这里我们又得分两种情况&#xff1a;行内元素还是 块状元素&#xff0c;块状元素里面又分为定宽块状元素&#xff0c;以及…...

企业网站备案密码怎么找回/商丘网站推广公司

过山车 Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 11520 Accepted Submission(s): 5072Problem DescriptionRPG girls今天和大家一起去游乐场玩。最终能够坐上梦寐以求的过山车了。但是&#xff0c;过山车…...

wordpress idstore/搜索引擎优化关键词的处理

1)将扫描枪电缆的一端与网络电缆的水晶头连接到扫描枪底部的插座。 当您听到“喀哒”声时&#xff0c;请再次将其拉回。 电缆不会滑出以表示已插入。另一端插入计算机上的相对端口号(此处以USB接口为例)。 此时&#xff0c;计算机的右下角将提醒您自动安装硬件配置驱动程序软件…...

深圳网站建设与推广/怎么推广app

事务代码&#xff1a;S_ABA_72000164 支持BDT导航和分析。...

网站建设的常用软件有哪些/seo网络培训班

前几天同一个朋友闲聊&#xff0c;他说了个很有意思的观点&#xff1a; 我们不招北大清华的。 因为大家都经过高考的折磨&#xff0c;所以心里对考上北大清华的都还是有点敬畏的&#xff0c;因此就追问了下原因。 他的回答很简单&#xff1a; 我们得承认这两所学校的人非常优秀…...