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

06排序 + 查找(D2_查找(D2_刷题练习))

目录

1. 二分查找-I

1.1 题目描述

1.2 解题思路

方法:二分法(推荐使用)

2. 二维数组中的查找

2.1 题目描述

2.2 解题思路

方法一:二分查找(推荐使用)

3. 寻找峰值

3.1 题目描述

3.2 解题思路

方法一:二分查找(推荐使用)

4. 数组中的逆序对

4.1 题目描述

4.2 解题思路

方法一:归并排序(推荐使用)

方法二:树状数组(扩展思路)

5. 旋转数组的最小数字

5.1 题目描述

5.2 解题思路

方法一:二分法(推荐使用)

方法二:遍历查找(扩展思路)

6. 比较版本号

6.1 题目描述

6.2 解题思路

方法一:双指针遍历截取(推荐使用)

方法二:分割截取(思路扩展)

7. 寻找文件副本

7.1 题目描述

7.2 解题思路

方法一:哈希表

方法二:原地交换

8. 统计目标成绩的出现次数

8.1 题目描述

8.2 解题思路

方法一:二分查找

9. 点名

9.1 题目描述

9.2 解题思路

方法一:二分查找

10. 招式拆解 II

10.1 题目描述

10.2 解题思路

方法一:哈希表

方法二:有序哈希表

11. 搜索插入位置

11.1 题目描述

11.2 解题思路

方法一:二分查找

12. 搜索二维矩阵

12.1 题目描述

12.2 解题思路

方法一:两次二分查找

方法二:一次二分查找

13. 在排序数组中查找元素的第一个和最后一个位置

13.1 题目描述

13.2 解题思路

方法一:二分查找

14. 搜索旋转排序数组

14.1 题目描述

14.2 解题思路

方法一:二分查找

15. 寻找旋转排序数组中的最小值

15.1 题目描述

15.2 解题思路

方法一:二分查找

16. 寻找两个正序数组的中位数

16.1 题目描述

16.2 解题思路

方法一:二分查找

方法二:划分数组

17. 猜数字大小

17.1 题目描述

17.2 解题思路

方法一:二分查找

18. 咒语和药水的成功对数

18.1 题目描述

18.2 解题思路

方法一:二分查找

方法二:双指针

19. 爱吃香蕉的珂珂

19.1 题目描述

19.2 解题思路

方法一:二分查找


1. 二分查找-I

1.1 题目描述

1.2 解题思路

方法:二分法(推荐使用)

Java实现代码:

import java.util.*;
public class Solution {public int search (int[] nums, int target) {int l = 0;int r = nums.length - 1;//从数组首尾开始,直到二者相遇while(l <= r){ //每次检查中点的值int m = (l + r) / 2; if(nums[m] == target)return m;//进入左的区间if(nums[m] > target) r = m - 1;//进入右区间else l = m + 1;}//未找到return -1; }
}

2. 二维数组中的查找

2.1 题目描述

2.2 解题思路

方法一:二分查找(推荐使用)

Java实现代码:

public class Solution {public boolean Find(int target, int [][] array) {//优先判断特殊if(array.length == 0)  return false;int n = array.length;if(array[0].length == 0)  return false;int m = array[0].length;//从最左下角的元素开始往左或往上for(int i = n - 1, j = 0; i >= 0 && j < m; ){ //元素较大,往上走if(array[i][j] > target)   i--;//元素较小,往右走else if(array[i][j] < target) j++;elsereturn true;}return false;}
}

3. 寻找峰值

3.1 题目描述

3.2 解题思路

方法一:二分查找(推荐使用)

Java实现代码:

import java.util.*;
public class Solution {public int findPeakElement (int[] nums) {int left = 0;int right = nums.length - 1;//二分法while(left < right){ int mid = (left + right) / 2;//右边是往下,不一定有坡峰if(nums[mid] > nums[mid + 1])right = mid;//右边是往上,一定能找到波峰elseleft = mid + 1;}//其中一个波峰return right; }
}

4. 数组中的逆序对

4.1 题目描述

4.2 解题思路

方法一:归并排序(推荐使用)

Java实现代码:

public class Solution {public int mod = 1000000007;public int mergeSort(int left, int right, int [] data, int [] temp){//停止划分if(left >= right)    return 0;//取中间int mid = (left + right) / 2; //左右划分合并int res = mergeSort(left, mid, data, temp) + mergeSort(mid + 1, right, data, temp); //防止溢出res %= mod;  int i = left, j = mid + 1;for(int k = left; k <= right; k++)temp[k] = data[k];for(int k = left; k <= right; k++){if(i == mid + 1)data[k] = temp[j++];else if(j == right + 1 || temp[i] <= temp[j])data[k] = temp[i++];//左边比右边大,答案增加else{ data[k] = temp[j++];// 统计逆序对res += mid - i + 1; }}return res % mod;}public int InversePairs(int [] array) {int n = array.length;int[] res = new int[n];return mergeSort(0, n - 1, array, res);}
}

方法二:树状数组(扩展思路)

import java.util.*;
class BIT {private int[] tree;private int n;//初始化树状数组的大小public BIT(int m) { this.n = m;this.tree = new int[m + 1];}//使数组呈现2、4、8、16这种树状public int lowbit(int x) { return x & (-x);}//查询序列1到x的前缀和public int query(int x) { int res = 0;while(x != 0){res += tree[x];x -= lowbit(x);}return res;}//序列x位置的数加1public void update(int x) { while(x <= n){tree[x]++;x += lowbit(x);}}
}public class Solution {public int mod = 1000000007;public int InversePairs(int [] array) {int n = array.length;int[] temp = new int[n];System.arraycopy(array, 0, temp, 0, n);//排序得到一份有序的数组Arrays.sort(temp); //二分法重新映射,将数字变成其在有序数组中的位置for (int i = 0; i < n; ++i) //二分法查找在其在有序数组中的位置array[i] = Arrays.binarySearch(temp, array[i]) + 1;//建立大小为n的树状数组BIT bit = new BIT(n); int res = 0;//统计逆序对for(int i = 0; i < n; i++){ //前缀和做差res = (res + bit.query(n) - bit.query(array[i])) % mod;bit.update(array[i]);}return res;}
}

5. 旋转数组的最小数字

5.1 题目描述

5.2 解题思路

方法一:二分法(推荐使用)

Java实现代码:

import java.util.ArrayList;
public class Solution {public int minNumberInRotateArray(int [] array) {int left = 0;int right = array.length - 1;while(left < right){int mid = (left + right) / 2;//最小的数字在mid右边if(array[mid] > array[right]) left = mid + 1;//无法判断,一个一个试else if(array[mid] == array[right]) right--;//最小数字要么是mid要么在mid左边else right = mid;}return array[left];}
}

方法二:遍历查找(扩展思路)

import java.util.*;
public class Solution {public int minNumberInRotateArray(int [] array) {//数组一定有元素int res = array[0]; //遍历数组for(int i = 1; i < array.length; i++) //每次维护最小值res = Math.min(res, array[i]); return res;}
}

6. 比较版本号

6.1 题目描述

6.2 解题思路

方法一:双指针遍历截取(推荐使用)

Java实现代码:

import java.util.*;
public class Solution {public int compare (String version1, String version2) {int n1 = version1.length();int n2 = version2.length();int i = 0, j = 0;//直到某个字符串结束while(i < n1 || j < n2){long num1 = 0;//从下一个点前截取数字while(i < n1 && version1.charAt(i) != '.'){ num1 = num1 * 10 + (version1.charAt(i) - '0');i++;}//跳过点i++; long num2 = 0;//从下一个点前截取数字while(j < n2 && version2.charAt(j) != '.'){ num2 = num2 * 10 + (version2.charAt(j) - '0');j++;}//跳过点j++; //比较数字大小if(num1 > num2) return 1;if(num1 < num2)return -1;}//版本号相同return 0; }
}

方法二:分割截取(思路扩展)

import java.util.*;
public class Solution {public int compare (String version1, String version2) {//按照.划分String[] nums1 = version1.split("\\."); String[] nums2 = version2.split("\\.");for(int i = 0; i < nums1.length || i < nums2.length; i++){//较短的版本号后续都取0String str1 = i < nums1.length ? nums1[i] : "0"; String str2 = i < nums2.length ? nums2[i] : "0";long num1 = 0;//字符串转数字for(int j = 0; j < str1.length(); j++) num1 = num1 * 10 + (str1.charAt(j) - '0');long num2 = 0;for(int j = 0; j < str2.length(); j++)num2 = num2 * 10 + (str2.charAt(j) - '0');//比较数字大小if(num1 > num2) return 1;if(num1 < num2)return -1;}//版本相同return 0;}
}

7. 寻找文件副本

7.1 题目描述

7.2 解题思路

方法一:哈希表

class Solution {public int findRepeatDocument(int[] documents) {Set<Integer> hmap = new HashSet<>();for(int doc : documents) {if(hmap.contains(doc)) return doc;hmap.add(doc);}return -1;}}

方法二:原地交换

class Solution {public int findRepeatDocument(int[] documents) {int i = 0;while(i < documents.length) {if(documents[i] == i) {i++;continue;}if(documents[documents[i]] == documents[i]) return documents[i];int tmp = documents[i];documents[i] = documents[tmp];documents[tmp] = tmp;}return -1;}}

8. 统计目标成绩的出现次数

8.1 题目描述

8.2 解题思路

方法一:二分查找

class Solution {public int countTarget(int[] scores, int target) {int leftIdx = binarySearch(scores, target, true);int rightIdx = binarySearch(scores, target, false) - 1;if (leftIdx <= rightIdx && rightIdx < scores.length && scores[leftIdx] == target && scores[rightIdx] == target) {return rightIdx - leftIdx + 1;} return 0;}public int binarySearch(int[] nums, int target, boolean lower) {int left = 0, right = nums.length - 1, ans = nums.length;while (left <= right) {int mid = (left + right) / 2;if (nums[mid] > target || (lower && nums[mid] >= target)) {right = mid - 1;ans = mid;} else {left = mid + 1;}}return ans;}
}

9. 点名

9.1 题目描述

9.2 解题思路

方法一:二分查找

class Solution {public int takeAttendance(int[] records) {int i = 0, j = records.length - 1;while(i <= j) {int m = (i + j) / 2;if(records[m] == m) i = m + 1;else j = m - 1;}return i;}}

10. 招式拆解 II

10.1 题目描述

10.2 解题思路

方法一:哈希表

class Solution {public char dismantlingAction(String arr) {HashMap<Character, Boolean> hmap = new HashMap<>();char[] sc = arr.toCharArray();for(char c : sc)hmap.put(c, !hmap.containsKey(c));for(char c : sc)if(hmap.get(c)) return c;return ' ';}}

方法二:有序哈希表

class Solution {public char dismantlingAction(String arr) {Map<Character, Boolean> hmap = new LinkedHashMap<>();char[] sc = arr.toCharArray();for(char c : sc)hmap.put(c, !hmap.containsKey(c));for(Map.Entry<Character, Boolean> d : hmap.entrySet()){if(d.getValue()) return d.getKey();}return ' ';}}

11. 搜索插入位置

11.1 题目描述

11.2 解题思路

方法一:二分查找

class Solution {public int searchInsert(int[] nums, int target) {int n = nums.length;int left = 0, right = n - 1, ans = n;while (left <= right) {int mid = ((right - left) >> 1) + left;if (target <= nums[mid]) {ans = mid;right = mid - 1;} else {left = mid + 1;}}return ans;}
}

12. 搜索二维矩阵

12.1 题目描述

12.2 解题思路

方法一:两次二分查找

class Solution {public boolean searchMatrix(int[][] matrix, int target) {int rowIndex = binarySearchFirstColumn(matrix, target);if (rowIndex < 0) {return false;}return binarySearchRow(matrix[rowIndex], target);}public int binarySearchFirstColumn(int[][] matrix, int target) {int low = -1, high = matrix.length - 1;while (low < high) {int mid = (high - low + 1) / 2 + low;if (matrix[mid][0] <= target) {low = mid;} else {high = mid - 1;}}return low;}public boolean binarySearchRow(int[] row, int target) {int low = 0, high = row.length - 1;while (low <= high) {int mid = (high - low) / 2 + low;if (row[mid] == target) {return true;} else if (row[mid] > target) {high = mid - 1;} else {low = mid + 1;}}return false;}
}

方法二:一次二分查找

class Solution {public boolean searchMatrix(int[][] matrix, int target) {int m = matrix.length, n = matrix[0].length;int low = 0, high = m * n - 1;while (low <= high) {int mid = (high - low) / 2 + low;int x = matrix[mid / n][mid % n];if (x < target) {low = mid + 1;} else if (x > target) {high = mid - 1;} else {return true;}}return false;}
}

13. 在排序数组中查找元素的第一个和最后一个位置

13.1 题目描述

13.2 解题思路

方法一:二分查找

class Solution {public int[] searchRange(int[] nums, int target) {int leftIdx = binarySearch(nums, target, true);int rightIdx = binarySearch(nums, target, false) - 1;if (leftIdx <= rightIdx && rightIdx < nums.length && nums[leftIdx] == target && nums[rightIdx] == target) {return new int[]{leftIdx, rightIdx};} return new int[]{-1, -1};}public int binarySearch(int[] nums, int target, boolean lower) {int left = 0, right = nums.length - 1, ans = nums.length;while (left <= right) {int mid = (left + right) / 2;if (nums[mid] > target || (lower && nums[mid] >= target)) {right = mid - 1;ans = mid;} else {left = mid + 1;}}return ans;}
}

14. 搜索旋转排序数组

14.1 题目描述

14.2 解题思路

方法一:二分查找

class Solution {public int search(int[] nums, int target) {int n = nums.length;if (n == 0) {return -1;}if (n == 1) {return nums[0] == target ? 0 : -1;}int l = 0, r = n - 1;while (l <= r) {int mid = (l + r) / 2;if (nums[mid] == target) {return mid;}if (nums[0] <= nums[mid]) {if (nums[0] <= target && target < nums[mid]) {r = mid - 1;} else {l = mid + 1;}} else {if (nums[mid] < target && target <= nums[n - 1]) {l = mid + 1;} else {r = mid - 1;}}}return -1;}
}

15. 寻找旋转排序数组中的最小值

15.1 题目描述

15.2 解题思路

方法一:二分查找

class Solution {public int findMin(int[] nums) {int low = 0;int high = nums.length - 1;while (low < high) {int pivot = low + (high - low) / 2;if (nums[pivot] < nums[high]) {high = pivot;} else {low = pivot + 1;}}return nums[low];}
}

16. 寻找两个正序数组的中位数

16.1 题目描述

16.2 解题思路

方法一:二分查找


 

class Solution {public double findMedianSortedArrays(int[] nums1, int[] nums2) {int length1 = nums1.length, length2 = nums2.length;int totalLength = length1 + length2;if (totalLength % 2 == 1) {int midIndex = totalLength / 2;double median = getKthElement(nums1, nums2, midIndex + 1);return median;} else {int midIndex1 = totalLength / 2 - 1, midIndex2 = totalLength / 2;double median = (getKthElement(nums1, nums2, midIndex1 + 1) + getKthElement(nums1, nums2, midIndex2 + 1)) / 2.0;return median;}}public int getKthElement(int[] nums1, int[] nums2, int k) {/* 主要思路:要找到第 k (k>1) 小的元素,那么就取 pivot1 = nums1[k/2-1] 和 pivot2 = nums2[k/2-1] 进行比较* 这里的 "/" 表示整除* nums1 中小于等于 pivot1 的元素有 nums1[0 .. k/2-2] 共计 k/2-1 个* nums2 中小于等于 pivot2 的元素有 nums2[0 .. k/2-2] 共计 k/2-1 个* 取 pivot = min(pivot1, pivot2),两个数组中小于等于 pivot 的元素共计不会超过 (k/2-1) + (k/2-1) <= k-2 个* 这样 pivot 本身最大也只能是第 k-1 小的元素* 如果 pivot = pivot1,那么 nums1[0 .. k/2-1] 都不可能是第 k 小的元素。把这些元素全部 "删除",剩下的作为新的 nums1 数组* 如果 pivot = pivot2,那么 nums2[0 .. k/2-1] 都不可能是第 k 小的元素。把这些元素全部 "删除",剩下的作为新的 nums2 数组* 由于我们 "删除" 了一些元素(这些元素都比第 k 小的元素要小),因此需要修改 k 的值,减去删除的数的个数*/int length1 = nums1.length, length2 = nums2.length;int index1 = 0, index2 = 0;int kthElement = 0;while (true) {// 边界情况if (index1 == length1) {return nums2[index2 + k - 1];}if (index2 == length2) {return nums1[index1 + k - 1];}if (k == 1) {return Math.min(nums1[index1], nums2[index2]);}// 正常情况int half = k / 2;int newIndex1 = Math.min(index1 + half, length1) - 1;int newIndex2 = Math.min(index2 + half, length2) - 1;int pivot1 = nums1[newIndex1], pivot2 = nums2[newIndex2];if (pivot1 <= pivot2) {k -= (newIndex1 - index1 + 1);index1 = newIndex1 + 1;} else {k -= (newIndex2 - index2 + 1);index2 = newIndex2 + 1;}}}
}

方法二:划分数组

class Solution {public double findMedianSortedArrays(int[] nums1, int[] nums2) {if (nums1.length > nums2.length) {return findMedianSortedArrays(nums2, nums1);}int m = nums1.length;int n = nums2.length;int left = 0, right = m;// median1:前一部分的最大值// median2:后一部分的最小值int median1 = 0, median2 = 0;while (left <= right) {// 前一部分包含 nums1[0 .. i-1] 和 nums2[0 .. j-1]// 后一部分包含 nums1[i .. m-1] 和 nums2[j .. n-1]int i = (left + right) / 2;int j = (m + n + 1) / 2 - i;// nums_im1, nums_i, nums_jm1, nums_j 分别表示 nums1[i-1], nums1[i], nums2[j-1], nums2[j]int nums_im1 = (i == 0 ? Integer.MIN_VALUE : nums1[i - 1]);int nums_i = (i == m ? Integer.MAX_VALUE : nums1[i]);int nums_jm1 = (j == 0 ? Integer.MIN_VALUE : nums2[j - 1]);int nums_j = (j == n ? Integer.MAX_VALUE : nums2[j]);if (nums_im1 <= nums_j) {median1 = Math.max(nums_im1, nums_jm1);median2 = Math.min(nums_i, nums_j);left = i + 1;} else {right = i - 1;}}return (m + n) % 2 == 0 ? (median1 + median2) / 2.0 : median1;}
}

17. 猜数字大小

17.1 题目描述

17.2 解题思路

方法一:二分查找

public class Solution extends GuessGame {public int guessNumber(int n) {int left = 1, right = n;while (left < right) { // 循环直至区间左右端点相同int mid = left + (right - left) / 2; // 防止计算时溢出if (guess(mid) <= 0) {right = mid; // 答案在区间 [left, mid] 中} else {left = mid + 1; // 答案在区间 [mid+1, right] 中}}// 此时有 left == right,区间缩为一个点,即为答案return left;}
}

18. 咒语和药水的成功对数

18.1 题目描述

18.2 解题思路

方法一:二分查找

class Solution {public int[] successfulPairs(int[] spells, int[] potions, long success) {Arrays.sort(potions);int n = spells.length, m = potions.length;int[] res = new int[n];for (int i = 0; i < n; i++) {long t = (success + spells[i] - 1) / spells[i] - 1;res[i] = m - binarySearch(potions, 0, m - 1, t);}return res;}public int binarySearch(int[] arr, int lo, int hi, long target) {int res = hi + 1;while (lo <= hi) {int mid = lo + (hi - lo) / 2;if (arr[mid] > target) {res = mid;hi = mid - 1;} else {lo = mid + 1;}}return res;}
}

方法二:双指针

class Solution {public int[] successfulPairs(int[] spells, int[] potions, long success) {int n = spells.length, m = potions.length;int[] res = new int[n];int[][] idx = new int[n][2];for (int i = 0; i < n; ++i) {idx[i][0] = spells[i];idx[i][1] = i;}Arrays.sort(potions);for (int i = 0, j = m - 1; i < j; ++i, --j) {int temp = potions[i];potions[i] = potions[j];potions[j] = temp;}Arrays.sort(idx, (a, b) -> a[0] - b[0]);for (int i = 0, j = 0; i < n; ++i) {int p = idx[i][1];int v = idx[i][0];while (j < m && (long) potions[j] * v >= success) {++j;}res[p] = j;}return res;}
}

19. 爱吃香蕉的珂珂

19.1 题目描述

19.2 解题思路

方法一:二分查找

class Solution {public int minEatingSpeed(int[] piles, int h) {int low = 1;int high = 0;for (int pile : piles) {high = Math.max(high, pile);}int k = high;while (low < high) {int speed = (high - low) / 2 + low;long time = getTime(piles, speed);if (time <= h) {k = speed;high = speed;} else {low = speed + 1;}}return k;}public long getTime(int[] piles, int speed) {long time = 0;for (int pile : piles) {int curTime = (pile + speed - 1) / speed;time += curTime;}return time;}
}

相关文章:

06排序 + 查找(D2_查找(D2_刷题练习))

目录 1. 二分查找-I 1.1 题目描述 1.2 解题思路 方法&#xff1a;二分法&#xff08;推荐使用&#xff09; 2. 二维数组中的查找 2.1 题目描述 2.2 解题思路 方法一&#xff1a;二分查找&#xff08;推荐使用&#xff09; 3. 寻找峰值 3.1 题目描述 3.2 解题思路 方…...

客户端渲染和服务端渲染

二者本质的区别&#xff1a;是在哪完成了 HTML 的拼接&#xff0c;服务端渲染是在服务端拼接&#xff0c;客户端渲染是在客户端拼接。 服务端渲染的优缺点 优点 SEO 友好&#xff0c;服务端渲染更有利于爬虫爬取信息。 更快的首屏渲染&#xff0c;因为 HTML 已经在服务端生…...

C++ 设计模式 - 访问者模式

一&#xff1a;概述 访问者模式将作用于对象层次结构的操作封装为一个对象&#xff0c;并使其能够在不修改对象层次结构的情况下定义新的操作。 《设计模式&#xff1a;可复用面向对象软件的基础》一书中的访问者模式因两个原因而具有传奇色彩&#xff1a;一是因为它的复杂性&a…...

海云安开发者智能助手(D10)全面接入DeepSeek,赋能开发者安全高效编码新范式

海云安正式宣布完成与DeepSeek&#xff08;深度求索&#xff09;的深度技术融合&#xff0c;旗下核心产品D10开发者智能助手全面接入DeepSeek R1模型。此次合作标志着海云安在"AI驱动开发安全"领域实现重要突破。数据显示&#xff0c;通过DeepSeek R1模型的优化与蒸馏…...

服务器绑定 127.0.0.1 和 0.0.0.0 的区别

前言 IP 地址实际上并不是分配给计算机的&#xff0c;而是分配给网卡的&#xff0c;因此当计算机上存在多块网卡时&#xff0c;每一块网卡都会有自己的 IP 地址。 绑定 127.0.0.1 是绑定到 lookback 这个虚拟的本地回环接口&#xff0c;该接口只处理本机上的数据&#xff0c;…...

ML.NET库学习005:基于机器学习的客户细分实现与解析

文章目录 ML.NET库学习005&#xff1a;基于机器学习的客户细分实现与解析项目主要目的和原理目的原理 项目概述实现的主要功能主要流程步骤使用的主要函数方法关键技术 主要功能和步骤功能详细解读详细步骤解析 数据集及其处理步骤数据集处理步骤关键处理步骤原理1. 数据清洗与…...

分布式id探索

一、为什么要使用分布式id&#xff1f; 随着数据量增加&#xff0c;数据需要进行水平拆分&#xff0c;但表自增id无法满足唯一性&#xff1b; 二、分布式id的特点 1唯一性 2 趋势递增、单调递增&#xff08;数据库中存放的数据结构数据从小到大有序排列&#xff09;&#xff0…...

互联网协议套件中的服务类型(RFC 1349)技术解析与总结

1. 背景与核心目标 RFC 1349 是对 IP 协议头部 服务类型&#xff08;Type of Service, TOS&#xff09;字段语义的更新与澄清文档&#xff0c;发布于 1992 年。其主要目标包括&#xff1a; 重新定义 TOS 字段的用途&#xff1a;明确 TOS 字段的语义&#xff0c;解决历史标准中的…...

java-初识List

List&#xff1a; List 是一个接口&#xff0c;属于 java.util 包&#xff0c;用于表示有序的元素集合。List 允许存储重复元素&#xff0c;并且可以通过索引访问元素。它是 Java 集合框架&#xff08;Java Collections Framework&#xff09;的一部分 特点&#xff1a; 有序…...

【Linux系统】—— 简易进度条的实现

【Linux系统】—— 简易进度条的实现 1 回车和换行2 缓冲区3 进度条的准备代码4 第一版进度条5 第二版进度条 1 回车和换行 先问大家一个问题&#xff1a;回车换行是什么&#xff0c;或者说回车和换行是同一个概念吗&#xff1f;   可能大家对回车换行有一定的误解&#xff0…...

一文学会:用DeepSeek R1/V3 + AnythingLLM + Ollama 打造本地化部署的个人/企业知识库,无须担心数据上传云端的泄露问题

文章目录 前言一、AnythingLLM 简介&基础应用1.主要特性2.下载与安装3.配置 LLM 提供商4.AnythingLLM 工作区&对话 二、AnythingLLM 进阶应用&#xff1a;知识增强使用三、AnythingLLM 的 API 访问四、小结1.聊天模式2.本地存储&向量数据库 前言 如果你不知道Olla…...

开源身份和访问管理方案之keycloak(一)快速入门

文章目录 什么是IAM什么是keycloakKeycloak 的功能 核心概念client管理 OpenID Connect 客户端 Client Scoperealm roleAssigning role mappings分配角色映射Using default roles使用默认角色Role scope mappings角色范围映射 UsersGroupssessionsEventsKeycloak Policy创建策略…...

C++STL(六)——list模拟

目录 本次所需实现的三个类一、结点类的模拟实现构造函数 二、迭代器类的模拟实现为什么有迭代器类迭代器类的模板参数说明构造函数运算符的重载- -运算符的重载和!运算符的重载*运算符的重载->运算符的重载引入模板第二个和第三个参数 三、list的模拟实现3.1 默认成员函数构…...

HTML5--网页前端编程(下)

HTML5–网页前端编程(下) 9.常用标签下 (1)表格标签 用来展示数据,显示数据,规整条理,可读性好 基本语法 <table><tr> <td>单元格内的文字</td> <td>单元格内的文字</td>… </tr> <tr> <td>单元格内的文字&l…...

Spring 的 ResponseEntity 包装器使用详解

简介 在 Spring 中&#xff0c;ResponseEntity 是 HTTP 响应的包装器。它允许自定义响应的各个方面&#xff1a; HTTP 状态码 响应主体 HTTP 请求头 使用 ResponseEntity 允许完全控制 HTTP 响应&#xff0c;并且它通常用于 RESTful Web 服务中从控制器方法返回响应。 基…...

Git 分布式版本控制工具使用教程

1.关于Git 1.1 什么是Git Git是一款免费、开源的分布式版本控制工具&#xff0c;由Linux创始人Linus Torvalds于2005年开发。它被设计用来处理从很小到非常大的项目&#xff0c;速度和效率都非常高。Git允许多个开发者几乎同时处理同一个项目而不会互相干扰&#xff0c;并且在…...

linux部署ollama+deepseek+dify

Ollama 下载源码 curl -L https://ollama.com/download/ollama-linux-amd64.tgz -o ollama-linux-amd64.tgz sudo tar -C /usr -xzf ollama-linux-amd64.tgz启动 export OLLAMA_HOST0.0.0.0:11434 ollama serve访问ip:11434看到即成功 Ollama is running 手动安装deepseek…...

torch_bmm验算及代码测试

文章目录 1. torch_bmm2. pytorch源码 1. torch_bmm torch.bmm的作用是基于batch_size的矩阵乘法,torch.bmm的作用是对应batch位置的矩阵相乘&#xff0c;比如&#xff0c; mat1的第1个位置和mat2的第1个位置进行矩阵相乘得到mat3的第1个位置mat1的第2个位置和mat2的第2个位置…...

Vue3 特点

不强制要求组件有根节点 // vue2 <template><div><h1>标题</h1><p>内容</p></div> </template>// vue3 <template><h1>标题</h1><p>内容</p> </template> 注意事项 虽然 Vue 3 不再强制…...

mysql8 C++源码中创建表函数,表字段最大数量限制,表行最大存储限制

在 MySQL 8 的 C 源码中&#xff0c;表的最大字段数量限制体现在 MAX_FIELDS 宏定义中。这个宏定义了表中可以拥有的最大字段数量。 代码中的体现 在 mysql_prepare_create_table 函数中&#xff0c;有以下代码段检查表的字段数量是否超过最大限制&#xff1a; cpp if (alt…...

CTFHub-RCE系列wp

目录标题 引言什么是RCE漏洞 eval执行文件包含文件包含php://input读取源代码远程包含 命令注入无过滤过滤cat过滤空格过滤目录分隔符过滤运算符综合过滤练习 引言 题目共有如下类型 什么是RCE漏洞 RCE漏洞&#xff0c;全称是Remote Code Execution漏洞&#xff0c;翻译成中文…...

【OneAPI】通过网页预渲染让搜索引擎收录网页

API简介 网页预渲染&#xff0c;适用于动态网页以及单页面的SEO&#xff0c;支持网页缓存。 您无须更改代码即可让搜索引擎收录您的网页。只要将需要预渲染的页面转发的本接口即可。 如果您使用Nginx作为网页服务器&#xff0c;推荐使用以下配置&#xff1a; #您的网站locat…...

从大规模恶意攻击 DeepSeek 事件看 AI 创新隐忧:安全可观测体系建设刻不容缓

作者&#xff1a;羿莉&#xff08;萧羿&#xff09; 全球出圈的中国大模型 DeepSeek 作为一款革命性的大型语言模型&#xff0c;以其卓越的自然语言处理能力和创新性成本控制引领行业前沿。该模型不仅在性能上媲美 OpenAI-o1&#xff0c;而且在推理模型的成本优化上实现了突破…...

【学习笔记】企业数字化转型顶层设计与企业架构TOGAF9.2-第0章 导论

数据要素资产化迈入关键发展期 围绕发挥数据要素乘数作用&#xff0c;研究实施“数据要素x”行动:从供需两端发力&#xff0c;在智能制造、商贸流通、交通物流、金融服务、医疗健康等若干重点领域&#xff0c;加强场景需求牵引&#xff0c;打通流通障碍、提升供给质量&#xf…...

Vue3 Ref全家桶深度解析:掌握响应式编程精髓

Vue3 Ref全家桶深度解析&#xff1a;掌握响应式编程精髓 一、Ref核心概念 1.1 响应式数据容器 const count ref(0) // 相当于创建了一个响应式容器&#xff1a; {value: 0,__v_isRef: true,// 其他响应式系统属性 }1.2 全家桶全景图 #mermaid-svg-VkHPjjlo16rOyItj {font-f…...

如何避免大语言模型中涉及丢番图方程的问题

希尔伯特第十问题是一个著名的数学问题,涉及不定方程(又称为丢番图方程)的可解答性。然而在大模型中,我们希望问题都是确定的可解的,或者说要尽可能的想办法避免不确定的不可解问题。由于丢番图方程问题是不可判定问题(即不存在一个有效的算法能够解决该类问题的所有实例…...

SpringCloud - Sentinel服务保护

前言 该博客为Sentinel学习笔记&#xff0c;主要目的是为了帮助后期快速复习使用 学习视频&#xff1a;7小快速通关SpringCloud 辅助文档&#xff1a;SpringCloud快速通关 源码地址&#xff1a;cloud-demo 一、简介 官网&#xff1a;https://sentinelguard.io/zh-cn/index.h…...

Java 使用腾讯翻译 API 实现含 HTML 标签文本,json值,精准翻译工具

注意&#xff1a;需搭配标题二的腾讯翻译工具使用 一-1、翻译标签文本工具 package org.springblade.common.utils;import java.util.ArrayList; import java.util.List; import java.util.regex.Matcher; import java.util.regex.Pattern;public class TencentTranslationFor…...

前端导出pdf,所见即所得

一、推荐方案&#xff1a;html2canvas jsPDF&#xff08;图片式PDF&#xff09; javascript import html2canvas from html2canvas; import jsPDF from jspdf;const exportPDF async (elementId, fileName) > {const element document.getElementById(elementId);// 1.…...

单片机上SPI和IIC的区别

SPI&#xff08;Serial Peripheral Interface&#xff09;和IC&#xff08;Inter-Integrated Circuit&#xff09;是两种常用的嵌入式外设通信协议&#xff0c;它们各有优缺点&#xff0c;适用于不同的场景。以下是它们的详细对比&#xff1a; — 1. 基本概念 SPI&#xff0…...