【leetcode刷题之路】剑指Offer(4)——分治+排序算法+动态规划

文章目录

      • 8 分治算法
        • 8.1 【递归】剑指 Offer 07 - 重建二叉树
        • 8.2 【递归】【快速幂】剑指 Offer 16 - 数值的整数次方
        • 8.3 【递归】剑指 Offer 33 - 二叉搜索树的后序遍历序列
        • 8.4 【递归】【分治】剑指 Offer 17 - 打印从1到最大的n位数
        • 8.5 【归并排序】【分治】剑指 Offer 51 - 数组中的逆序对
      • 9 排序
        • 9.1 【冒泡排序】剑指 Offer 45 - 把数组排成最小的数
        • 9.2 【排序】剑指 Offer 61 - 扑克牌中的顺子
        • 9.3 【堆排序】剑指 Offer 40 - 最小的k个数
        • 9.4 【堆排序】【优先队列】剑指 Offer 41 - 数据流中的中位数
      • 10 动态规划
        • 10.1 【动态规划】【哈希表】【DFS】剑指 Offer 10- I - 斐波那契数列
        • 10.2 【动态规划】【哈希表】【DFS】剑指 Offer 10- II - 青蛙跳台阶问题
        • 10.3 【动态规划】剑指 Offer 63 - 股票的最大利润
        • 10.4 【动态规划】【分治】剑指 Offer 42 - 连续子数组的最大和
        • 10.5 【动态规划】剑指 Offer 47 - 礼物的最大价值

8 分治算法

8.1 【递归】剑指 Offer 07 - 重建二叉树

https://leetcode.cn/problems/zhong-jian-er-cha-shu-lcof/

  前序遍历是根左右,中序遍历是左根右,这也就意味着前序遍历的第一个节点是整棵树的根节点,顺着这个节点找到它在中序遍历中的位置,即为in_root,那么in_root左边的都在左子树,右边的都在右子树,这样就可以知道左子树一共有多少个节点,然后去前序遍历中找到左右子树的分界点,分成左右两部分,分别重复上述过程,找到各自部分的第一个根节点,然后再依次往下进行,直到最后左右子树的边界发生重合,此时二叉树重建完毕。

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode(int x) : val(x), left(NULL), right(NULL) {}* };*/
class Solution {
private:unordered_map<int,int> hash_table;
public:TreeNode* subTree(vector<int>& preorder, vector<int>& inorder, int pre_l, int pre_r, int in_l, int in_r){if(pre_l > pre_r) return nullptr;//找到根节点,计算左子树的节点数int pre_root = pre_l;int in_root = hash_table[preorder[pre_l]];int sub_l = in_root - in_l;//开始生成rootTreeNode* root = new TreeNode(preorder[pre_l]);//对于左子树而言,前序遍历的[左边界+1,左边界+左子树节点数]即为中序遍历的[左边界,根节点-1]root->left = subTree(preorder, inorder, pre_l+1, pre_l+sub_l, in_l, in_root-1);//对于右子树而言,前序遍历的[左边界+左子树节点数+1,右边界]即为中序遍历的[根节点+1,右边界]root->right = subTree(preorder, inorder, pre_l+sub_l+1, pre_r, in_root+1, in_r);return root;}TreeNode* buildTree(vector<int>& preorder, vector<int>& inorder) {int n = inorder.size();for(int i=0;i<n;i++){hash_table[inorder[i]] = i;}return subTree(preorder, inorder, 0, n-1, 0, n-1);}
};

8.2 【递归】【快速幂】剑指 Offer 16 - 数值的整数次方

https://leetcode.cn/problems/shu-zhi-de-zheng-shu-ci-fang-lcof/description/

  这道题可以用快速幂来解决,具体思路就是把幂次按照二进制拆开,分别计算,下面举个例子: 假设我要计算 x 10 x^{10} x10,因为10的二进制表示为1010,那么 x 10 = x 2 0 ∗ 0 ∗ x 2 1 ∗ 1 ∗ x 2 2 ∗ 0 ∗ x 2 3 ∗ 1 x^{10}=x^{2^0*0}*x^{2^1*1}*x^{2^2*0}*x^{2^3*1} x10=x200x211x220x231,可以看作按照x的2次方依次递增,只需要看这一个次方对应的二进制是否为1。

class Solution {
public:double myPow(double x, int n) {if(x==1 || n==0) return 1;if(x==0) return 0;double ans = 1;long num = n;if(n<0){num = -num;x = 1/x;}while(num){if(num & 1) ans *= x;x *= x;num >>= 1;}return ans;}
};

8.3 【递归】剑指 Offer 33 - 二叉搜索树的后序遍历序列

https://leetcode.cn/problems/er-cha-sou-suo-shu-de-hou-xu-bian-li-xu-lie-lcof

  后序遍历的特点就是先访问左子树再访问右子树最后访问根节点,所以最后一个元素一定根节点,而二叉搜索树的特点就是左子树<根节点<右子树,所以我们可以根据根节点的值把数组分为两部分,然后分别判断是否符合二叉搜索树的特点,重复上述过程直到所有情况都判断完为止。

class Solution {
public:bool dfs(vector<int>& postorder, int left, int right){if(left >= right) return true;int i = left;while(postorder[i]<postorder[right]){i++;}int mid = i;while(postorder[i]>postorder[right]){i++;}return i==right & dfs(postorder,left,mid-1) & dfs(postorder,mid,right-1);}bool verifyPostorder(vector<int>& postorder){return dfs(postorder,0,postorder.size()-1);}
};

8.4 【递归】【分治】剑指 Offer 17 - 打印从1到最大的n位数

https://leetcode.cn/problems/da-yin-cong-1dao-zui-da-de-nwei-shu-lcof

  这道题目由于指定了数组是int型,所以不用考虑大整数问题,直接暴力就可以解决,但如果是大整数的话,需要采用分治递归的思想,主要如下:

(1)第一层遍历,为n,分别考虑到生成的数字是1位数、2位数、3位数…n位数;

(2)第二层遍历,分别遍历每一位数是几,除了第一位是1-9之外,其余都是0-9。

class Solution {
public:vector<int> printNumbers(int n) {int cnt = pow(10,n);vector<int> ans;for(int i=1;i<cnt;i++){ans.push_back(i);}return ans;}
};

8.5 【归并排序】【分治】剑指 Offer 51 - 数组中的逆序对

https://leetcode.cn/problems/shu-zu-zhong-de-ni-xu-dui-lcof

  这位大佬写的很好!(https://leetcode.cn/problems/shu-zu-zhong-de-ni-xu-dui-lcof/solutions/622496/jian-zhi-offer-51-shu-zu-zhong-de-ni-xu-pvn2h)

class Solution {
public:int merge_sort(int left, int right, vector<int>& nums, vector<int>& tmp){if(left >= right) return 0;int mid = (left + right) / 2;int res = merge_sort(left, mid, nums, tmp) + merge_sort(mid+1, right, nums, tmp);int i = left, j = mid + 1;for(int k=left;k<=right;k++){tmp[k] = nums[k];}for(int k=left;k<=right;k++){ if(i == mid+1) nums[k] = tmp[j++];else if(j == right+1 || tmp[i] <= tmp[j]) nums[k] = tmp[i++];else{nums[k] = tmp[j++];res += mid - i + 1;}}return res;}int reversePairs(vector<int>& nums){vector<int> tmp(nums.size());return merge_sort(0, nums.size()-1, nums, tmp);}
};

9 排序

9.1 【冒泡排序】剑指 Offer 45 - 把数组排成最小的数

https://leetcode.cn/problems/ba-shu-zu-pai-cheng-zui-xiao-de-shu-lcof

  这题可以看作是冒泡排序,只不过针对的对象是字符串,我们需要找到里面表示最大的字符串,然后把它放到字符串的最后即可,例如“32”和“3”,因为“323”<“332”,所以“32”<“3”,所以应该把“3”放在“32”后面,借助这种排序思路来解题。

class Solution {
public:string minNumber(vector<int>& nums) {for(int i=nums.size()-1;i>0;i--){for(int j=0;j<i;j++){if(string_sort(nums[j],nums[j+1])){swap(nums[j],nums[j+1]);}}}string ans = "";for(int i=0;i<nums.size();i++){ans += to_string(nums[i]);}return ans;}bool string_sort(int num1, int num2){string s1 = to_string(num1) + to_string(num2);string s2 = to_string(num2) + to_string(num1);if(s1>s2) return true;else return false;}
};

9.2 【排序】剑指 Offer 61 - 扑克牌中的顺子

https://leetcode.cn/problems/bu-ke-pai-zhong-de-shun-zi-lcof

  这道题不难,想清楚顺子的判断条件即可,主要为以下几个方面:

(1)五个数中除了0以外不能有其他的重复数字,否则肯定不是顺子;

(2)找出五个数中的最大值和最小值,看看这两个数之间缺的数的个数是多少,记为gap,然后计算五个数中0的个数,记为zero_num,如果gap<=zero_num,说明0的个数可以补全缺的数,否则就肯定不是顺子。

class Solution {
public:bool isStraight(vector<int>& nums) {int arr[14] = {0};int max_num = 0, min_num = 14, zero_num = 0;for(int i=0;i<5;i++){if(nums[i]==0) zero_num++;else{if(arr[nums[i]]) return false;else{arr[nums[i]] = 1;min_num = min(min_num, nums[i]);max_num = max(max_num, nums[i]);}}}int gap = 0;for(int i=min_num;i<max_num;i++){if(arr[i]!=1) gap++;}if(gap <= zero_num) return true;else return false;}
};

9.3 【堆排序】剑指 Offer 40 - 最小的k个数

https://leetcode.cn/problems/zui-xiao-de-kge-shu-lcof

  方法一:直接用sort排序,然后选前k个数就好了。

  方法二:用堆排序,堆排序,采用大根堆,首先把前k个数字存入大根堆中,之后的数字依次和大根堆的top比较,如果比top小就更新大根堆,最后把大根堆中的数字存入vector中作为答案返回。

//方法一:直接排序
class Solution {
public:vector<int> getLeastNumbers(vector<int>& arr, int k) {sort(arr.begin(),arr.end());vector<int> ans;for(int i=0;i<k;i++){ans.push_back(arr[i]);}return ans;}
};
//方法二:堆排序
class Solution {
public:vector<int> getLeastNumbers(vector<int>& arr, int k) {vector<int> ans;if(k == 0) return ans;priority_queue<int, vector<int>, less<int>> max_stack;//把前k个数字存入大根堆for(int i=0;i<k;i++){max_stack.push(arr[i]);}//依次和大根堆的top比较,如果比top小就更新大根堆for(int j=k;j<arr.size();j++){if(arr[j] < max_stack.top()){max_stack.pop();max_stack.push(arr[j]);}}//把大根堆中的数字存入vector中作为答案返回while(k--){ans.push_back(max_stack.top());max_stack.pop();}return ans;}
};

9.4 【堆排序】【优先队列】剑指 Offer 41 - 数据流中的中位数

https://leetcode.cn/problems/shu-ju-liu-zhong-de-zhong-wei-shu-lcof

  这道题如果直接对所有数进行排序的话,最后会runtime,其实只要能找出每一次执行findMedian函数时整个数据流中间的两个数或者一个数就行了,这是我们可以考虑用堆排序,同时维持一个大根堆和一个小根堆,把数据流中的数分为两部分,同时也要保证大根堆中的top要比小根堆中的top小,这样最后的中位数要么是小根堆top,要么就是大根堆和小根堆的top取平均,构造方法如下:

  • 如果大根堆和小根堆的size一样,那么此时add的num就加入大根堆,然后把大根堆的top插入到小根堆中,保证大根堆的size<=小根堆的size;
  • 如果大根堆和小根堆的size不一样,那么此时add的num就加入小根堆,然后把小根堆的top插入到大根堆中,保证小根堆的size<=大根堆的size;
  • 执行findMedian函数时,看看此时大根堆和小根堆的size是否相等,如果相等的话,中位数就是各自取top元素相加取平均,如果不相等,那么中位数就是小根堆的top。
class MedianFinder {
public:/** initialize your data structure here. */priority_queue<int, vector<int>, greater<int>> min_stack;priority_queue<int, vector<int>, less<int>> max_stack;MedianFinder() {}void addNum(int num) {//如果大根堆和小根堆的size一样,那么此时add的num就加入大根堆,然后把大根堆的top插入到小根堆中,保证大根堆的size<=小根堆的sizeif(min_stack.size() == max_stack.size()){max_stack.push(num);min_stack.push(max_stack.top());max_stack.pop();}//如果大根堆和小根堆的size不一样,那么此时add的num就加入小根堆,然后把小根堆的top插入到大根堆中,保证小根堆的size<=大根堆的sizeelse{min_stack.push(num);max_stack.push(min_stack.top());min_stack.pop();}}//执行findMedian函数时,看看此时大根堆和小根堆的size是否相等,如果相等的话,中位数就是各自取top元素相加取平均,如果不相等,那么中位数就是小根堆的topdouble findMedian() {if(min_stack.size() == max_stack.size()){return (max_stack.top() + min_stack.top()) / 2.0;}else return min_stack.top();}
};/*** Your MedianFinder object will be instantiated and called as such:* MedianFinder* obj = new MedianFinder();* obj->addNum(num);* double param_2 = obj->findMedian();*/

10 动态规划

10.1 【动态规划】【哈希表】【DFS】剑指 Offer 10- I - 斐波那契数列

https://leetcode.cn/problems/fei-bo-na-qi-shu-lie-lcof

  这道题如果直接用动态规划会runtime,主要是因为在计算过程中会有一些数被反复计算,所以我们在这里采用哈希表来存放已经被计算过的数,这样在之后再次被计算时直接用就好了。

class Solution {
public:unordered_map<int,int> hash_table;int dfs(int n){if(n == 0) return 0;else if(n == 1) return 1;else{if(hash_table.count(n)) return hash_table[n];else{int num1 = dfs(n-1) % 1000000007;int num2 = dfs(n-2) % 1000000007;hash_table[n] = (num1 + num2) % 1000000007;return hash_table[n];}}}int fib(int n) {return dfs(n);}
};

10.2 【动态规划】【哈希表】【DFS】剑指 Offer 10- II - 青蛙跳台阶问题

https://leetcode.cn/problems/qing-wa-tiao-tai-jie-wen-ti-lcof

  这道题目就是变形的斐波那契数列,在这里采用哈希表来存放已经被计算过的数,这样在之后再次被计算时直接用就好了。

class Solution {
public:unordered_map<int,int> hash_table;int dfs(int n){if(n == 0) return 1;else if(n == 1) return 1;else{if(hash_table.count(n)) return hash_table[n];else{int num1 = dfs(n-1) % 1000000007;int num2 = dfs(n-2) % 1000000007;hash_table[n] = (num1 + num2) % 1000000007;return hash_table[n];}}}int numWays(int n) {return dfs(n);}
};

10.3 【动态规划】剑指 Offer 63 - 股票的最大利润

https://leetcode.cn/problems/gu-piao-de-zui-da-li-run-lcof

  动态规划类题目的解题主要是找到状态转移方程就好了,对于这道题目的状态转移就在于某一天有无股票,我们以此为分界来定义状态转移方程dp[i][2]:

(1)前i天未持有股票

d p [ i ] [ 0 ] = m a x ( d p [ i − 1 ] [ 0 ] , d p [ i − 1 ] [ 1 ] + p r i c e s [ i ] ) dp[i][0] = max(dp[i-1][0], dp[i-1][1] + prices[i]) dp[i][0]=max(dp[i1][0],dp[i1][1]+prices[i])

(2)前i天持有股票

d p [ i ] [ 1 ] = m a x ( d p [ i − 1 ] [ 1 ] , 0 − p r i c e s [ i ] ) dp[i][1] = max(dp[i-1][1], 0 - prices[i]) dp[i][1]=max(dp[i1][1],0prices[i])

  同时还要预判一下prices为空的情况,此时返回0,因为dp的两个元素在反复调用,所以在代码中也是直接用两个变量来进行代替了。

class Solution {
public:int maxProfit(vector<int>& prices) {if(!prices.size()) return 0;int dp_0 = 0, dp_1 = -prices[0];for(int i=1;i<prices.size();i++){dp_0 = max(dp_0, dp_1 + prices[i]);dp_1 = max(dp_1, 0 - prices[i]);}return dp_0;}
};

10.4 【动态规划】【分治】剑指 Offer 42 - 连续子数组的最大和

https://leetcode.cn/problems/lian-xu-zi-shu-zu-de-zui-da-he-lcof

  这道题用到一点点分治的思想,假设现在数组长度为 n n n,连续子数组的最大和为 f ( n ) f(n) f(n),那么 f ( n ) = m a x ( f ( n − 1 ) + n u m s [ i ] , n u m [ i ] ) f(n)=max(f(n-1)+nums[i],num[i]) f(n)=max(f(n1)+nums[i],num[i]),也就意味着最大和要么是前 n − 1 n-1 n1个数的最大和加上第 i i i个数,要么就是第 i i i个数本身,如果是第 i i i个数本身的话,就要从这里开始重新找到连续子数组了,在这个过程中记录下最大值即可。

class Solution {
public:int maxSubArray(vector<int>& nums) {int pre = 0, max_seqsum = nums[0];for(int i=0;i<nums.size();i++){pre = max(pre + nums[i], nums[i]);max_seqsum = max(max_seqsum, pre);}return max_seqsum;}
};

10.5 【动态规划】剑指 Offer 47 - 礼物的最大价值

https://leetcode.cn/problems/li-wu-de-zui-da-jie-zhi-lcof

  其实每个地方的最大值只与两个状态有关,假设目前要求的是 v a l u e [ i ] [ j ] value[i][j] value[i][j]的最大值,那么 v a l u e [ i ] [ j ] = m a x ( v a l u e [ i ] [ j − 1 ] , v a l u e [ i − 1 ] [ j ] ) + g r i d [ i ] [ j ] value[i][j] = max(value[i][j-1],value[i-1][j]) + grid[i][j] value[i][j]=max(value[i][j1],value[i1][j])+grid[i][j],这里为了方便初始化,把初始数组的大小设置为 ( m + 1 ) ∗ ( n + 1 ) (m+1)*(n+1) (m+1)(n+1)

class Solution {
public:int maxValue(vector<vector<int>>& grid) {int m = grid.size(), n = grid[0].size();int value[m+1][n+1];memset(value,0,sizeof(value));for(int i=0;i<m;i++){for(int j=0;j<n;j++){value[i+1][j+1] = max(value[i+1][j],value[i][j+1]) + grid[i][j];}}return value[m][n];}
};

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

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

相关文章

[论文阅读笔记25]A Comprehensive Survey on Graph Neural Networks

这是一篇GNN的综述, 发表于2021年的TNNLS. 这篇博客旨在对GNN的基本概念做一些记录. 论文地址: 论文 1. 引言, 背景与定义 对于图像数据来说, CNN具有平移不变性和局部连接性, 因此可以在欧氏空间上良好地学习. 然而, 对于具有图结构的数据(例如社交网络 化学分子等)就需要用…

Qt5升级到Qt6分步迁移教程

Qt框架的一个新的长期支持版本6.5最近发布。它为以前的版本引入了许多修复、改进和新功能。有些可能对您的应用程序有用&#xff08;如果不是现在&#xff0c;可能会在将来&#xff09;&#xff0c;因此最好将应用程序迁移到最新版本的框架。 仍然有许多应用程序仍在使用Qt 5&…

SpringDataRedis 使用

1. SpringDataRedis 特点2. 使用 SpringDataRedis 步骤3. 自定义 RedisTemplate 序列化4. SpringDataRedis 操作对象 1. SpringDataRedis 特点 提供了对不同 Redis 客户端的整合&#xff08;Lettuce 和 Jedis&#xff09;提供了 RedisTemplate 统一 API 来操作 Redis支持 Redi…

C++ 改善程序的具体做法 学习笔记

1、尽量用const enum inline替换#define 因为#define是做预处理操作&#xff0c;编译器从未看见该常量&#xff0c;编译器刚开始编译&#xff0c;它就被预处理器移走了&#xff0c;而#define的本质就是做替换&#xff0c;它可能从来未进入记号表 解决方法是用常量替换宏 语言…

安装VS2005时提示:请插入磁盘:visual studio 2005 DVD

安装VS2005时提示&#xff1a;请插入磁盘:visual studio 2005 DVD 修改卷标为 "DVD1"

Spring Cache的介绍以及怎么使用(redis)

Spring Cache 文章目录 Spring Cache1、Spring Cache介绍2、Spring Cache常用注解2.1、EnableCaching注解2.2、CachePut注解2.3、CacheEvict注解2.4、Cacheable注解 3、Spring Cache使用方式--redis 1、Spring Cache介绍 Spring Cache是一个框架&#xff0c;实现了基于注解的缓…

C++--动态规划背包问题(1)

1. 【模板】01背包_牛客题霸_牛客网 你有一个背包&#xff0c;最多能容纳的体积是V。 现在有n个物品&#xff0c;第i个物品的体积为vivi​ ,价值为wiwi​。 &#xff08;1&#xff09;求这个背包至多能装多大价值的物品&#xff1f; &#xff08;2&#xff09;若背包恰好装满&a…

【数据结构】排序(插入、选择、交换、归并) -- 详解

一、排序的概念及其运用 1、排序的概念 排序&#xff1a;所谓排序&#xff0c;就是使一串记录&#xff0c;按照其中的某个或某些关键字的大小&#xff0c;递增或递减的排列起来的操作。 稳定性&#xff1a;假定在待排序的记录序列中&#xff0c;存在多个具有相同的关键字的记…

pytorch 基于masking对元素进行替换

描述 pytorch 基于masking对元素进行替换. 代码如下. 先展平再赋值. 代码 # map.shape [64,60,128] # infill.shape [64,17,128] # mask_indices.shape [64,60]map map.reshape(map.shape[0] * map.shape[1],map.shape[2]) [mask_indices.reshape(mask_indices.shape[0]*ma…

文件属性与目录

目录 Linux 系统中的文件类型普通文件目录文件字符设备文件和块设备文件符号链接文件管道文件套接字文件总结 stat 函数struct stat 结构体st_mode 变量struct timespec 结构体练习 fstat 和lstat 函数fstat 函数lstat 函数 文件属主有效用户ID 和有效组IDchown 函数fchown 和l…

K8s 在创建pod时api-server是先找scheduler 还是controller-manager

在K8s中&#xff0c;创建Pod时的流程如下&#xff1a; 用户通过Kubectl或其他方式向API Server发送创建Pod的请求。API Server接收到请求后&#xff0c;会先进行权限验证和身份认证。一旦验证通过&#xff0c;API Server会将请求转发给Scheduler组件。Scheduler负责对新创建的…

leetcode 567. 字符串的排列(滑动窗口-java)

滑动窗口 字符串的排列滑动窗口代码演示进阶优化版 上期经典 字符串的排列 难度 -中等 leetcode567. 字符串的排列 给你两个字符串 s1 和 s2 &#xff0c;写一个函数来判断 s2 是否包含 s1 的排列。如果是&#xff0c;返回 true &#xff1b;否则&#xff0c;返回 false 。 换句…

Oracle监听器启动出错:本地计算机上的OracleOraDb11g_home1TNSListener服务启动后又停止了解决方案

在启动oracle的服务OracleOraDb11g_home1TNSListener时&#xff0c;提示服务启动后又停止了。 解决方法&#xff1a; 修改oracle安装目录下的两个配置文件&#xff1a; 以上两个文件&#xff0c;对应的HOST的值&#xff0c;都改为127.0.0.1 然后再启动服务&#xff0c;启动成…

【Python】Python 常量定义

Python 常量定义 Python中存在常量吗&#xff1f;相信很多人的答案是否定的。 实际上Pythrni的内建命名空间是 支持一小部分常量的&#xff0c; 如我们熟悉的True、False、None等&#xff0c;只是Python没有提供定义常量 的直接方式而已。 那么&#xff0c;在Python中应该如何…

大集合拆分成多个小集合

文章目录 1. 场景2. 拆分集合方法&#xff08;写了三种&#xff09;3. 格式化打印方法 1. 场景 在数据库批量操作时&#xff0c;有可能数据量过大&#xff0c;不能一次性操作&#xff0c;所以需要将大集合拆分为多个小集合进行多次操作 2. 拆分集合方法&#xff08;写了三种&…

Linux通过libudev获取挂载路径、监控U盘热拔插事件、U盘文件系统类型

文章目录 获取挂载路径监控U盘热拔插事件libusb 文件系统类型通过挂载点获取挂载路径添libudev加库 获取挂载路径 #include <stdio.h> #include <libudev.h> #include <string.h>int main() {struct udev *udev;struct udev_enumerate *enumerate;struct ud…

Android Activity启动过程一:从Intent到Activity创建

关于作者&#xff1a;CSDN内容合伙人、技术专家&#xff0c; 从零开始做日活千万级APP。 专注于分享各领域原创系列文章 &#xff0c;擅长java后端、移动开发、人工智能等&#xff0c;希望大家多多支持。 目录 一、概览二、应用内启动源码流程 (startActivity)2.1 startActivit…

curl通过webdav操作alist

创建目录: url202320230828;curl -v -u "admin":"这里是密码" -X MKCOL "http://127.0.0.1:5244/dav/my189tianyi/${url2023}/" 上传文件: curl -v -u "admin":"这里是密码" -T /tmp/aa.json "http://127.0.0.1:52…

Win10上ffmpeg出现Invalid report file level

在win10上经常使用ffmpeg&#xff0c;但是最近突然ffmpeg用不了&#xff0c;不管ffmpeg还是ffplay&#xff0c;输出始终一句话&#xff1a; Invalid report file level 重新通过scoop装了以后还是同样的错误。 后来发现是一个环境变量设置有问题&#xff0c;FFREPORT。 我在w…

flink on yarn with kerberos 边缘提交

flink on yarn 带kerberos 远程提交 实现 flink kerberos 配置 先使用ugi进行一次认证正常提交 import com.google.common.io.Files; import lombok.extern.slf4j.Slf4j; import org.apache.commons.io.FileUtils; import org.apache.flink.client.cli.CliFrontend; import o…