蓝桥杯真题Day40 倒计时19天 纯练题!

news2024/12/24 8:23:24

蓝桥杯第十三届省赛真题-统计子矩阵

题目描述

给定一个 N × M 的矩阵 A,请你统计有多少个子矩阵 (最小 1 × 1,最大 N × M) 满足子矩阵中所有数的和不超过给定的整数 K? 

输入格式

第一行包含三个整数 N, M 和 K. 

之后 N 行每行包含 M 个整数,代表矩阵 A.

输出格式

一个整数代表答案。

样例输入

3 4 10
1 2 3 4
5 6 7 8
9 10 11 12

样例输出

19

提示

满足条件的子矩阵一共有 19,包含:

大小为 1 × 1 的有 10 个。

大小为 1 × 2 的有 3 个。

大小为 1 × 3 的有 2 个。

大小为 1 × 4 的有 1 个。

大小为 2 × 1 的有 3 个。

对于 30% 的数据,N, M ≤ 20. 对于 70% 的数据,N, M ≤ 100. 

对于 100% 的数据,1 ≤ N, M ≤ 500; 0 ≤ Ai j ≤ 1000; 1 ≤ K ≤ 250000000.

思路提示

1.求每列前缀和(i,j 为上下边界,则可看成用一维解决)。
2.用双指针 l, r 维护左右边界,当 r 边界确定时(找到了 sum > k 的区间),左边界 l 往右移寻找符合条件的区间。

代码表示

#include <bits/stdc++.h>
using namespace std;

const int N = 510;
int f[N][N];//二维数组 f可以存储整型数据
int n, m, k;
int main()
{
    cin >> n >> m >> k;
    for (int i = 1; i <= n; i ++ )
        for (int j = 1; j <= m; j ++ )
            scanf("%d", &f[i][j]),
            f[i][j] += f[i - 1][j]; // 计算每列前缀和
            
    long long res = 0;
    for (int i = 1; i <= n; i ++ ) // 上边界
        for (int j = i; j <= n; j ++ ) // 下边界
            for (int l = 1, r = 1, sum = 0; r <= m; r ++ )
            {
                sum += f[j][r] - f[i - 1][r]; // 确定右边界 删去上面的 
                while (sum > k) // 求符合条件的左边界 l
                {
                    sum -= f[j][l] - f[i - 1][l];//删除左面的不用的 
                    l ++ ;
                }
                res += r - l + 1; 
            }
    cout << res;
    return 0;
}

心得体会

1、f[i][j] += f[i - 1][j] 时,它的含义是将当前位置 (i, j) 的值加上前一行相同列位置 (i - 1, j) 的值,并将结果保存在当前位置 (i, j)。这是累加前缀和的操作,用于计算子矩阵的和。

2、sum += f[j][r] - f[i - 1][r]; 用于计算当前子矩阵的和。f[j][r] - f[i - 1][r] 表示从上边界 i 到下边界 j、从左边界到右边界 r 的子矩阵的和

3、sum -= f[j][l] - f[i - 1][l]; l ++ ; 通过减去左边界 l 的前缀和,来找到符合条件的左边界。l 逐渐向右移动,直到子矩阵的和不超过 K。

4、res += r - l + 1; 将以当前 (i, j, r) 为边界的子矩阵的个数加到结果变量 res 中。r - l + 1 表示符合条件的子矩阵的列数。


蓝桥杯第十二届省赛真题-砝码称重

题目描述

你有一架天平和 N 个砝码,这 N 个砝码重量依次是 W1, W2, · · · , WN。
请你计算一共可以称出多少种不同的重量?
注意砝码可以放在天平两边。

输入格式

输入的第一行包含一个整数 N。
第二行包含 N 个整数:W1, W2, W3, · · · , WN。

输出格式

输出一个整数代表答案。

样例输入

3
1 4 6

样例输出

10

提示

【样例说明】
能称出的 10 种重量是:1、2、3、4、5、6、7、9、10、11。
1 = 1;
2 = 6 4 (天平一边放 6,另一边放 4);
3 = 4 1;
4 = 4;
5 = 6 1;
6 = 6;
7 = 1 + 6;
9 = 4 + 6 1;
10 = 4 + 6;
11 = 1 + 4 + 6。
【评测用例规模与约定】
对于 50% 的评测用例,1 ≤ N ≤ 15。
对于所有评测用例,1 ≤ N ≤ 100,N 个砝码总重不超过 100000。

代码表示

#include <bits/stdc++.h>
using namespace std;
//砝码个数N 
const int N = 110, M = 300000;//大一点好 
int n,sum,w[N];//总重量 sum 
int f[N][M];
int main()
{
    cin >> n;
    for (int i = 1;i <= n; i++)
    {
    	//读砝码每一个的重量w[i],累加到总重量 sum
        cin >> w[i];
        sum += w[i];
    }
    f[0][0]=1; //初始化 
    for(int i = 1; i <= n; i++)
    {
        for(int j = 0; j <= sum; j++)
        {
        //1、f[i-1][j]意味着不选第i个就可以达到重量j
        //2、f[i-1][j+w[i]]意味着第i个将放在另一边抵消w[i]达到j
        //3、f[i-1][abs(j-w[i])]意味着用第i个补上w[i]达到j
            f[i][j] = f[i - 1][j] || f[i - 1][j + w[i]] || f[i - 1][abs(j - w[i])];
        }
    }
    int ans = 0;
    //从 1 到总重量的所有可能的值 
    for(int i = 1; i <= sum; i++)//0不可能,故从1开始遍历
        if(f[n][i]) ans++;
    cout << ans;
    return 0;
}

心得体会

1、定义一个大小为 N×M 的二维数组 f,其中 f[i][j] 表示在前 i 个砝码中是否可以通过选择一些砝码,使得它们的总重量等于 j。M 的取值为 sum 的两倍,因为最坏情况下,所有砝码都放在一侧,另一侧没有砝码。

2、当我们计算 f[i][j] 时,我们需要考虑前 i 个砝码中是否存在一些砝码的选择,使得它们的总重量等于 j。

  • f[i][j] = f[i-1][j+w[i]]:这个转移表示我们选择了第 i 个砝码,并将其放在另一侧以抵消重量 w[i],使得总重量达到 j。因此,我们可以从前 i-1 个砝码中选择一些砝码,使得它们的总重量为 j+w[i]。
  • f[i][j] = f[i-1][abs(j-w[i])]:这个转移表示我们选择了第 i 个砝码,并把它加到总重量为 j 的一侧,使得总重量达到 j。因此,我们可以从前 i-1 个砝码中选择一些砝码,使得它们的总重量为 abs(j-w[i])。

这两个转移的含义是根据砝码的放置方式进行考虑的。我们可以选择将第 i 个砝码放在天平的左侧或右侧,或者不选择第 i 个砝码。因此,通过考虑这些不同的放置方式,我们可以计算出 f[i][j] 的值。

3、这个题,一开始拿到就觉得肯定不是简单的正向思维,果然是套者一个东西来做整体遍历的。


蓝桥杯2021年第十二届省赛真题-异或数列

题目描述

Alice 和 Bob 正在玩一个异或数列的游戏。初始时,Alice 和 Bob 分别有一个整数 a 和 b,有一个给定的长度为 n 的公共数列 X1, X2, · · · , Xn。
Alice 和 Bob 轮流操作,Alice 先手,每步可以在以下两种选项中选一种:
选项 1:从数列中选一个 Xi 给 Alice 的数异或上,或者说令 a 变为 a ⊕ Xi。(其中 ⊕ 表示按位异或)
选项 2:从数列中选一个 Xi 给 Bob 的数异或上,或者说令 b 变为 b ⊕ Xi。每个数 Xi 都只能用一次,当所有 Xi 均被使用后(n 轮后)游戏结束。游戏结束时,拥有的数比较大的一方获胜,如果双方数值相同,即为平手。
现在双方都足够聪明,都采用最优策略,请问谁能获胜?

输入格式

每个评测用例包含多组询问。询问之间彼此独立。
输入的第一行包含一个整数 T,表示询问数。
接下来 T 行每行包含一组询问。其中第 i 行的第一个整数 ni 表示数列长度,随后 ni 个整数 X1, X2, · · · , Xni 表示数列中的每个数。

输出格式

输出 T 行,依次对应每组询问的答案。
每行包含一个整数 1、0 或 1 分别表示 Alice 胜、平局或败。

样例输入

4
1 1
1 0
2 2 1
7 992438 1006399 781139 985280 4729 872779 563580

样例输出

1
0
1
1

提示

思路提示

使用res记录所有x的异或结果

1、res==0,平局

2、res!=0,( num数组记录每位的1的个数,从最高位for(i)查看Number[i] )
1)num[i]==1,该位数只要一个1,Alice 先手,胜
2)num[i]是偶数,无影响,不处理
3)num[i]是奇数:① n是偶数,1是奇数,那么0是奇数,只要后手把0先选完,后手就获得最后一个1的支配权,后手胜。②同理可得,n是奇数,0是偶数,先手把0先选完,先手获得最后一个1的支配权,先手胜

3、异或赋值运算符 ^=

4、if(x&1) num[cnt]++;:判断 x 的最低位是否为 1,即 x 的二进制表示的最低位是否为 1。如果是,则将数组 num 中对应位置 cnt 的计数值加 1。

1)x&1 是按位与操作,用来提取 x 的最低位的值。因为 1 的二进制表示为 0001,其他位为 0,所以与 1 进行按位与操作,就可以得到 x 的最低位的值。

2)如果 x 的最低位为 1,说明当前位上有一个 1,所以将数组 num 中对应位 cnt 的计数值加 1。

代码表示

#include <bits/stdc++.h>
using namespace std;

int num[22];  //记录每位的1的个数 
void pre(int x)//计算一个数的二进制表示中每位上 1 的个数 
{
  int cnt=1;
  while(x)
  {
    if(x&1) num[cnt]++;
//将 x 右移一位,即将 x 的二进制表示向右移动一位。
    x>>=1;
    cnt++;
  }
}
int main(){
    int T;  //询问数
    cin>>T;
    while(T--){
        memset(num,0,sizeof(num));
        int n,res=0; //res存储xi元素异或结果 
        cin>>n;  
        for(int i=0;i<n;++i){
            int x;
            scanf("%d",&x);
            pre(x);
            //异或 相同的数异或结果为 0,不同的数异或结果为 1
            res^=x; 
        }
        if(res==0){
//平局先手无论怎么选择,后手都可以通过合理的选择使得异或结果保持为 0 
            printf("0\n"); 
        }else{
            for(int k=20;k>0;k--){
                if(num[k]==1){
                    printf("1\n");
                    break;
                }
                //1的个数是奇数 
                if(num[k]%2==1){
                    if(n%2==0){
 //1是奇数,n是偶数,那么0是奇数,只要后手把0先选完,后手就获得最后一个1的支配权,后手胜 
                        printf("-1\n"); 
                        break; 
                    }else{
//同理可得,n是奇数,0是偶数,先手把0先选完,先手获得最后一个1的支配权,先手胜利
                        printf("1\n"); 
                        break;
                    }
                }
            }
        }
    }
    return 0;
}

蓝桥杯第十二届省赛真题-左孩子右兄弟(再看)

题目描述

对于一棵多叉树,我们可以通过 “左孩子右兄弟” 表示法,将其转化成一棵二叉树。
如果我们认为每个结点的子结点是无序的,那么得到的二叉树可能不唯一。换句话说,每个结点可以选任意子结点作为左孩子,并按任意顺序连接右兄弟。
给定一棵包含 N 个结点的多叉树,结点从 1 至 N 编号,其中 1 号结点是根,每个结点的父结点的编号比自己的编号小。请你计算其通过 “左孩子右兄弟” 表示法转化成的二叉树,高度最高是多少。注:只有根结点这一个结点的树高度为 0 。

例如如下的多叉树:

输入格式

输入的第一行包含一个整数 N。
以下 N 1 行,每行包含一个整数,依次表示 2 至 N 号结点的父结点编号。

输出格式

输出一个整数表示答案。

样例输入

5
1
1
1
2

样例输出

4

提示

【评测用例规模与约定】

对于 30% 的评测用例,1 ≤ N ≤ 20;对于所有评测用例,1 ≤ N ≤ 100000。

代码表示

方法一:深搜

对于节点 i,在其子节点中找出:令该节点作为根节点时可以使高度最大的节点 j

令节点 j 作为 i 的子节点中最后一个出现的节点,可使高度达到最大。

#include <bits/stdc++.h>
using namespace std;
const int MAXN = 100005;//最大结点数 
  
int n, tmp;
vector<int> mp[MAXN];//存储多叉树的边关系 
 
//递归函数 dfs计算以结点 idx 为根的子树的高度。 
int dfs(int idx)
{
    int sz = mp[idx].size();//获取结点 idx 的子结点的个数
    int ans = 0;//存储最大高度 
    for (int i = 0; i < sz; i++) 
	{
	//更新 ans,取当前子树的高度和已有的最大高度的较大值。 
        ans = max(ans, dfs(mp[idx][i]));
    }
    return ans + sz;//最大子树高度加上当前结点的子结点个数
}
  
int main() {
    cin >> n;
    for (int i = 2; i <= n; i++) {
        cin >> tmp;//读取结点 i 的父结点编号存储到 tmp 中
        mp[tmp].push_back(i);//将结点 i 添加为结点 tmp 的子结点
    }
    cout << dfs(1) << endl;//计算以结点 1 为根的子树的高度
    return 0;
}

方法二:动态规划

用数组 s[i] 表示节点 i 的子节点个数,用数组 f[i] 表示节点 i 的父节点,dp[i] 表示当节点 i 作为根节点时的最大高度,可以推断出如下状态转移方程:dp[ f [ i ] ] = max(dp[ f [ i ] ], s[ f [ i ] ] + dp[ i ]);

由于子节点一定比父节点的编号大,所以对节点编号逆向遍历即可。

1、逆序的循环,从最后一个节点开始,逐步向前遍历每个节点。

在循环中,我们首先通过 int fa = f[i]; 语句获取当前节点 i 的父节点编号,并将其存储在变量 fa 中。然后,我们使用 dp[fa] = max(dp[fa], s[fa] + dp[i]); 更新父节点 fa 的最大高度。这行代码的目的是比较父节点 fa 的当前最大高度 dp[fa] <可能还有其他同级的点>和考虑将当前节点 i 作为子节点时的高度 s[fa] + dp[i],然后取二者中的较大值,并将较大值赋值给 dp[fa],从而更新父节点的最大高度。

这个循环的作用是逐步从叶节点向根节点更新每个节点的最大高度,确保每个节点的最大高度都被正确计算和更新。通过这个过程,我们最终可以得到整棵树的最大高度。

2、dp[fa] 表示节点 fa(父节点)作为根节点时的最大高度。s[fa] 表示节点 fa 的子节点个数。dp[i] 表示节点 i 作为根节点时的最大高度。

#include <bits/stdc++.h>
using namespace std;
const int MAXN = 100005;
 
//temp:存储读取到的节点 i 的父节点编号 
int n, tmp;
//下面分别是子节点个数、父节点和最大高度
int s[MAXN], f[MAXN], dp[MAXN];
  
int main() 
{
    cin >> n;
    for (int i = 2; i <= n; i++) {
        cin >> tmp;
        f[i] = tmp;
        s[tmp]++;
    }
//逆向遍历节点编号更新节点 fa 作为根节点时的最大高度
    for (int i = n; i > 1; i--) {
        int fa = f[i];//获取结点 i 的父结点编号
        dp[fa] = max(dp[fa], s[fa] + dp[i]);
    }
    cout << dp[1] << endl;
    return 0;
}

蓝桥杯第十二届省赛真题-括号序列

题目描述

给定一个括号序列,要求尽可能少地添加若干括号使得括号序列变得合法,当添加完成后,会产生不同的添加结果,请问有多少种本质不同的添加结果。两个结果是本质不同的是指存在某个位置一个结果是左括号,而另一个是右括号。
例如,对于括号序列 (((),只需要添加两个括号就能让其合法,有以下几种不同的添加结果:()()()、()(())、(())()、(()()) 和 ((()))。

输入格式

输入一行包含一个字符串 s,表示给定的括号序列,序列中只有左括号和
右括号。

输出格式

输出一个整数表示答案,答案可能很大,请输出答案除以 1000000007 (即109 + 7) 的余数。

样例输入

((()

样例输出

5

提示

【评测用例规模与约定】

对于 40% 的评测用例,|s| ≤ 200。

对于所有评测用例,1 ≤ |s| ≤ 5000。

代码表示:

#include <bits/stdc++.h>
using namespace std;

const int N = 5005;
int f[N][N];
int mod = 1e9 + 7;
string s;
int n;

long long get() {
    memset(f, 0, sizeof f);//memset 将二维数组 f 初始化为全零
    f[0][0] = 1;
    for (int i = 1; i <= n; i++) {
        if (s[i - 1] == '(') {
            for (int j = 1; j <= n; j++)
                f[i][j] = f[i - 1][j - 1];//表示在当前位置放置一个左括号
        } else {
//需要考虑两种情况。
//第一是不将当前位置的括号与之前的任何位置的括号匹配, f[i][0] 的值为 f[i-1][1] + f[i-1][0]。
//第二是将当前位置的括号与之前的某个位置的括号匹配, f[i][j] 的值为 f[i-1][j+1] + f[i][j-1]
            f[i][0] = (f[i - 1][1] + f[i - 1][0]) % mod;
            for (int j = 1; j <= n; j++)
                f[i][j] = (f[i - 1][j + 1] + f[i][j - 1]) % mod;
        }
    }
//我们遍历 f[n] 数组的所有元素,如果某个元素不为零,则返回它作为结果。
//如果所有元素都为零,则返回 -1
    for (int i = 0; i <= n; i++) {
        if (f[n][i])
            return f[n][i];
    }
    return -1;
}

int main() {
    cin >> s;
    n = s.size();
    long long x = get();
    reverse(s.begin(), s.end());
    for (int i = 0; i < n; i++) {
        if (s[i] == ')')
            s[i] = '(';
        else
            s[i] = ')';
    }
    long long y = get();
    cout << (x * y) % mod;

    return 0;
}

心得体会:

在赛场上骗分的时候要用所给的示例,确实有一点点的分

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

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

相关文章

机器学习模型——KNN

KNN的基本概念&#xff1a; KNN(K-Nearest Neighbor)就是k个最近的邻居的意思&#xff0c;即每个样本都可以用它最接近的k个邻居来代表。KNN常用来处理分类问题&#xff0c;但也可以用来处理回归问题。 核心思想是如果一个样本在特征空间中的k个最相邻的样本中的大多数属于某…

好物视频素材哪里找,下面推荐几个好用给大家

想要创作出精彩的好物视频&#xff0c;离不开优质的素材。在这里&#xff0c;我将介绍一些提供免费好物视频素材的网站&#xff0c;让你轻松找到所需素材。 首先&#xff0c;蛙学网&#xff08;https://www.waxuewang.com&#xff09;是一个提供高质量视频素材的网站&#xff…

Redis面试题-缓存雪崩、缓存穿透、缓存击穿问题

1 穿透: 两边都不存在&#xff08;皇帝的新装&#xff09; &#xff08;黑名单&#xff09; &#xff08;布隆过滤器&#xff09; 2 击穿&#xff1a;一个热点的key失效了&#xff0c;这时大量的并发请求直接到达数据库. &#xff08;提前预热&#xff09; 3 雪崩&#xff1a…

好物视频素材库免费下载去哪找?

你是不是在找抖音好物视频素材库免费的网站&#xff0c;可是不知道哪儿能找到&#xff1f;别急&#xff0c;我来给你推荐几个网站&#xff0c;保证让你找到满意的素材&#xff01; 首先&#xff0c;蛙学网&#xff08;https://www.waxuewang.com&#xff09;是一个提供高质量视…

电子价签通信协议解析:蓝牙5.0有何优势?

电子价签是一种新型的零售显示技术&#xff0c;它可以实时更新商品价格、促销信息等内容&#xff0c;为消费者提供更加便捷的购物体验。电子价签的通信协议是决定其性能的关键因素之一&#xff0c;而蓝牙5.0则是目前相对更适合电子价签的通信协议。 电子价签的工作模式 以云…

Notepad++:格式化json字符串(带转义)

目录 一、效果呈现 二、去除json字符串转义 三、格式化json字符串 一、效果呈现 格式化前 带字符串转义&#xff0c;带unicode编码字符 格式化后 二、去除json字符串转义 方法&#xff1a;采用Notepad的普通替换 第一&#xff1a;\"替换为" 第二&#xff1a;\\…

智能算法-遗传算法 学习笔记

适应度的计算可类别为神经网络的目标函数&#xff0c;但此算法属于无监督学习&#xff0c;宏观来讲为搜寻最优解&#xff08;梯度&#xff09;的方式不同&#xff1f; 但神经网络中好像并不存在变异操作&#xff08;参数矩阵突变&#xff09;&#xff1f; 交叉的话残差网络ResN…

第一性原理计算代码可使用1个月有效期,龙讯旷腾PWmat

龙讯旷腾系列产品正在陆续入驻国家超算互联网&#xff08;https://www.scnet.cn&#xff09;&#xff0c;有自己的网上商城了&#xff01;PWmat&#xff08;如果您喜欢命令行&#xff09;以及Q-FlowPWmat组合产品&#xff08;如果您喜欢用可视化工作流提交任务&#xff09;&…

iOS网络抓包工具全解析

摘要 本文将深入探讨iOS平台上常用的网络抓包工具&#xff0c;包括Charles、克魔助手、Thor和Http Catcher&#xff0c;以及通过SSH连接进行抓包的方法。此外&#xff0c;还介绍了克魔开发助手作为iOS应用开发的辅助工具&#xff0c;提供的全方面性能监控和调试功能。 在iOS应…

nodejs中使用WebScoket的简单示例

前言 WebScoket可以用来实现即时通信,一般用于通信聊天工具或者是需要实时接受数据等功能 在浏览器环境中,WebScoket是一个构造函数,需要new创建连接的实例; 在nodejs环境中,则需要使用ws模块来完成服务的创建。 示例 下面是可以直接使用的代码,不需要修改 node创建服务端…

31-3 文件包含漏洞 - 文件包含漏洞利用(CVE-2021-3019:Lanproxy 任意文件读取漏洞复现)

一、Lanproxy简介: lanproxy是一个将局域网个人电脑、服务器代理到公网的内网穿透工具,支持TCP流量转发,可支持任何TCP上层协议(访问内网网站、本地支付接口调试、SSH访问、远程桌面等)。 二、漏洞概述: Lanproxy1.0 版本存在目录遍历漏洞,可通过绕过路径限制(../)来…

手游行业如何做好软文推广?媒介盒子揭秘

随着各方面消费持续复苏&#xff0c;手游行业也在逐渐回暖&#xff0c;为了宣传游戏特色和积累游戏热度&#xff0c;很多运营商都会在各大平台投放软文。然而有许多商家在软文投放时只关注数量 不关注质量&#xff0c;导致软文效果不是很好。今天媒介盒子就来和大家聊聊&#x…

机器学习 | 期望最大化(EM)算法介绍和实现

在现实世界的机器学习应用中&#xff0c;通常有许多相关的特征&#xff0c;但只有其中的一个子集是可观察的。当处理有时可观察而有时不可观察的变量时&#xff0c;确实可以利用该变量可见或可观察的实例&#xff0c;以便学习和预测不可观察的实例。这种方法通常被称为处理缺失…

【C++】手撕哈希表的闭散列和开散列

> 作者&#xff1a;დ旧言~ > 座右铭&#xff1a;松树千年终是朽&#xff0c;槿花一日自为荣。 > 目标&#xff1a;手撕哈希表的闭散列和开散列 > 毒鸡汤&#xff1a;谁不是一边受伤&#xff0c;一边学会坚强。 > 专栏选自&#xff1a;C嘎嘎进阶 > 望小伙伴们…

全国超市数据可视化仪表板制作

全国超市消费数据展示 指定 Top几 客户销费数据展示 指定 Top几 省份销费数据展示 省份销售额数据分析 完整结果

蓝牙耳机哪个品牌质量最好最耐用?购前必读的高热度机型指南!

​面对市场上众多不同场景使用的蓝牙耳机&#xff0c;我们该如何选择呢&#xff1f;我们最怕遇到耳机延迟高、不防水防汗、音质差以及佩戴体验差的问题。针对这些常见问题&#xff0c;我这次精选了五款市面上热销且质量不错的蓝牙耳机分享给大家&#xff0c;让我们一起来看看吧…

当当狸智能激光雕刻机 多种材质自由雕刻,轻松打造独一无二的作品

提及“激光雕刻”&#xff0c;大多数人的印象一般都是&#xff1a;笨重巨大、价格昂贵、操作复杂、使用门槛较高、调试难度大...不是普通人能够随意操作的&#xff0c;让人望尘莫及。 而小米有品上新的这台「当当狸桌面智能激光雕刻机L1」&#xff0c;将超乎你的想象&#xff…

【unity】如何汉化unity编译器

在【unity】如何汉化unity Hub这篇文章中&#xff0c;我们已经完成了unity Hub的汉化&#xff0c;现在让我们对unity Hub安装的编译器也进行下汉化处理。 第一步&#xff1a;在unity Hub软件左侧栏目中点击安装&#xff0c;选择需要汉化的编译器&#xff0c;再点击设置图片按钮…

【MATLAB源码-第171期】基于matlab的布谷鸟优化算法(COA)无人机三维路径规划,输出做短路径图和适应度曲线

操作环境&#xff1a; MATLAB 2022a 1、算法描述 布谷鸟优化算法&#xff08;Cuckoo Optimization Algorithm, COA&#xff09;是一种启发式搜索算法&#xff0c;其设计灵感源自于布谷鸟的独特生活习性&#xff0c;尤其是它们的寄生繁殖行为。该算法通过模拟布谷鸟在自然界中…

RabbitMQ 的高阶应用及可靠性保证

目录 一、RabbitMQ 高阶应用 1.1 消息何去何从 1.2 过期时间 1.3 死信队列 1.4 延迟队列 1.5 优先级队列 1.6 消费质量保证&#xff08;QOS&#xff09; 二、持久化 三、生产者确认 四、消息可靠性和重复消费 4.1 消息可靠性 4.2 重复消费问题 上篇文章介绍了 Rabb…