蓝桥杯c++算法秒杀【6】之动态规划【上】(数字三角形、砝码称重(背包问题)、括号序列、组合数问题:::非常典型的必刷例题!!!)

news2025/1/13 9:33:30

 下将以括号序列、组合数问题超级吧难的题为例子讲解动态规划 

别忘了请点个赞+收藏+关注支持一下博主喵!!!!  !  !  !  !

关注博主,更多蓝桥杯nice题目静待更新:)

动态规划

一、数字三角形 

【问题描述】

        上图给出了一个数字三角形。从三角形的顶部到底部有很多条路径。对于每条路径, 把路径上面的数加起来可以得到一个和,你的任务就是找到最大的和。

        路径上的每一步只能从一个数走到下一层和它最近的左边的那个数或者右边的那个 数。此外,向左下走的次数与向右下走的次数相差不能超过1。  

【输入格式】

         输入的第一行包含一个整数N(1⩽N⩽100),表示三角形的行数。 

        下面的N行给出数字三角形。数字三角形上的数都是0至100之间的整数。

【输出格式】

        输出一个整数表示答案。

【样例输入】

        

【样例输出】

         27

解析: 

        本题是十分经典的动态规划题。

        为了方便存储与操作,可以将题目描述中的等腰三角形转换为直角三角形,如下图所示。

        将其转换为直角三角形后,就可以用一个二维数组(a[][])来存储它。这样三角形第i行 的第j 个数字就可以通过a[i][j] 来表示。同时原来向左下走就变为了向下走,本题下文解析所说的“向下走”即为“向左下走”,向右下走还是向右下走。

        在处理完样例输入后,我们来尝试对题目进行求解。

         由于“向左下走的次数与向右下走的次数相差不能超过1”这个限制条件看上去比较复杂,所以我们可将该题分解为两个子问题: 第一个子问题是不考虑限制条件,只解决如何走的问题;第二个子问题是加上这个限制条件找到走到底部的最大路径和,从而完整解答出本题。对于每个子问题,都分别用DFS和动态规划两种方式来解题,大家可进一步体验这两种方式的特点。 

解决子问题1:DFS模式

        题目要求我们从三角形的顶部开始走,而顶部只有一个数字a[1][1],所以所走路径的起点一定是a[1][1]。

         由于我们每一步只能向下走或者向右下走,因此a[1][1]的下一步只有以下两种可能。

        (1)走向a[2][1]。

        (2)走向a[2][2]。

        具体要走向哪个呢?我们并不好确定。

        我们能得知的是,如果设dfs(i,j) 表示从 a[i][j] 走到底部的最大路径和,那么我们一定会走向max(dfs(2,1),dfs(2,2)) 所对应的路径,即从 a[1][1] 走到底部的最大路径和:

        在该式子中,dfs(1,1) 是我们要求解的,a[1][1] 是已知的,dfs(2,1)、dfs(2,2) 是未知的。 显然,只要存在未知数,就无法求解dfs(1,1)的值。因此,必须先求解dfs(2,1) 和dfs(2,2)。

        但要怎么求解它们呢? 我们以求解dfs(i,j) 为例。

        当a[i][j](i < n) 不在底部时,每一步只能向下走或者向右下走,因此a[i][j] 的下一步只有两种可能。

        (1)走向a[i+1][j]。

        (2)走向a[i+1][j +1]。 当a[i][j](i = n) 在底部时,我们将无法再走任何一步。 由此可得 :

参考代码如下 【时间复杂度为 O(2^{n})】 

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

const int N = 1e2 + 10;
int n, a[N][N];

int dfs(int i, int j) {
    if (i == n) return a[i][j]; // 走到底部无法再走了,直接返回
    return max(dfs(i + 1, j), dfs(i + 1, j + 1)) + a[i][j];
}

signed main() {
    cin >> n;

    for (int i = 1; i <= n; i++) {
        for (int j = 1; j <= i; j++) {
            cin >> a[i][j];
        }
    }

    cout << dfs(1, 1) << '\n';
    return 0;
}

        在上方代码中,每次dfs都几乎调用了自己两次,所以代码的时间复杂度约为O(2^{n})。 

        如果一个三角形的行数为4,则程序的递归过程将如下图所示。

        显然,O(2^{n}) 的时间复杂度是十分低效的,无法帮助我们顺利解出本题。至于复杂度低效的原因,从上图中不难发现是因为在递归的过程中做了过多重复的计算,比如在上图中, dfs(3, 2) 就重复计算了一次。

         那么,我们要如何避免递归时的重复计算呢?

        可以采用一个简单且高效的方法——记忆化,即定义一个二维数组res[][],用res[i][j]保 存dfs(i,j) 的计算结果。当再次需要dfs(i,j) 的计算结果时,直接返回res[i][j] 即可,无须继续递归下去。

        使用了记忆化的方法优化后,最多只需进行约n^{2}次递归。 

参考代码如下 【时间复杂度为 O(n^{2})】

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

const int N = 1e2 + 10;
int n, a[N][N], res[N][N];

int dfs(int i, int j) {
    if (res[i][j]) return res[i][j]; // 如果 res[i][j] 不为 0,说明已经计算过,直接返回结果
    
    if (i == n) return a[i][j]; // 到达底部,返回当前值
    return res[i][j] = max(dfs(i + 1, j), dfs(i + 1, j + 1)) + a[i][j]; // 计算并存储结果
}

signed main() {
    cin >> n;

    for (int i = 1; i <= n; i++) {
        for (int j = 1; j <= i; j++) {
            cin >> a[i][j];
        }
    }

    cout << dfs(1, 1) << '\n';
    return 0;
}
解决子问题1:动态规划模式

        与DFS 不同的是,动态规划通常是采用递推的方式从上到下来求解问题。

        在本题中,我们从三角形的顶部(1,1)走到三角形的某个位置(i,j)的方法颇多,根据不同的走法,所得到的路径和可能会有所差异。

         由于本题需要求解的是从三角形顶部(1,1) 走到底部的最大路径和,所以在不同方法带 来的不同路径和中,我们只需要关注最大路径和即可。

         于是,我们可以定义一个数组dp[][],其中dp[i][j] 用以表示从三角形顶部(11) 走到(ij) 的所有路径和中的最大值。

         当走到底部时,所处的位置可能有(n,1)、(n,2)、...、(n,n),它们对应的最大路径和分 别为dp[n][1]、dp[n][2]、...、dp[n][n]。我们要的是这当中的最大路径和,即 

        起初,处于三角形的顶部(1,1)。因为从(1,1) 走到(1,1) 的方法仅有一种,所以我们可 得dp[1][1] = a[1][1]。

        (1)从位置(i−1,j) 向下走一步。

        (2)从位置(i−1,j−1) 向右下走一步。

        无论我们选择哪种,从(1,1) 到(i,j) 的路径与 (1,1) 到 (i−1,j) 或 (i−1,j−1) 的路径都只会有一步之差。所以两种方法到达(i,j)的最大路径和分别如下。

        (1)dp[i−1][j]+a[i][j]。

        (2)dp[i−1][j −1]+a[i][j]。

        为了使到达位置(i,j) 的路径和最大,我们需要从这两种方法中选择较大的一种,即

        这样,我们便完成了dp方程的转移。       

参考代码如下 【时间复杂度为 O(n^{2})】  

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

const int N = 1e2 + 10;
int n, a[N][N], dp[N][N];

signed main() {
    cin >> n;

    for (int i = 1; i <= n; i++) {
        for (int j = 1; j <= i; j++) {
            cin >> a[i][j];
        }
    }

    dp[1][1] = a[1][1];

    for (int i = 2; i <= n; i++) {
        for (int j = 1; j <= i; j++) {
            dp[i][j] = max(dp[i - 1][j], dp[i - 1][j - 1]) + a[i][j];
        }
    }

    int ans = 0;
    for (int j = 1; j <= n; j++) {
        ans = max(ans, dp[n][j]);
    }

    cout << ans << '\n';
    return 0;
}

提示: 以上情况都是在不考虑“向左下走的次数与向右下走的次数相差不能超过1”这个限制 条件下分析的,接下来我们来思考加上向左下走的次数与向右下走的次数相差不能超过1这个限制条件之后该如何处理,即解决子问题2。

        为了方便读者理解,接下来我们分别用动态规划和DFS两种方法对本题进行讲解。

解决子问题2:动态规划模式

        我们可以采用最简单的方法:从顶部向底部走的过程中,额外添加一个状态——向下走 的次数,即定义dp[i][j][k]表示从(1,1)走到(i,j)一共向下走了k次的最大和。

         根据向下走和向右下走的次数相差不能超过1的条件,那么从第1行到第n行一共要走 n−1步,由此可得:

        •当n−1为奇数(n为偶数)时,向下走的次数可以为 \frac{n - 1}{2},也可以为 \frac{n - 1}{2} +1;

         •当n−1为偶数(n为奇数)时,向下走的次数只能为 \frac{n - 1}{2}

        那么答案就可表示为:

        对于位置(i,j),它可以由位置 (i − 1,j) 向下走了一步得到,也可以由位置(i−1,j−1) 向右下走了一步得到,于是dp转移方程为 

参考代码如下【时间复杂度为O(n^{3})】 

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

const int N = 1e2 + 10;
int n, a[N][N], dp[N][N][N];

signed main() {
    memset(dp, -0x3f, sizeof(dp)); // 某些情况可能并不存在,如 dp[2][1][0]:走到位置 (2,1) 时共向下走了 0 次。为了防止这种情况被转移,需初始化 dp 数组
    cin >> n;

    for (int i = 1; i <= n; i++) {
        for (int j = 1; j <= i; j++) {
            cin >> a[i][j];
        }
    }

    dp[1][1][0] = a[1][1];

    for (int i = 2; i <= n; i++) {
        for (int j = 1; j <= i; j++) {
            for (int k = 0; k <= (n - 1); k++) {
                if (!k) {
                    dp[i][j][k] = dp[i - 1][j - 1][k] + a[i][j];
                } else {
                    dp[i][j][k] = max(dp[i - 1][j - 1][k], dp[i - 1][j][k - 1]) + a[i][j];
                }
            }
        }
    }

    int ma = 0;
    if ((n - 1) & 1) {
        for (int j = 1; j <= n; j++) {
            ma = max(ma, max(dp[n][j][(n - 1) / 2], dp[n][j][(n - 1) / 2 + 1]));
        }
    } else {
        for (int j = 1; j <= n; j++) {
            ma = max(ma, dp[n][j][(n - 1) / 2]);
        }
    }

    cout << ma << '\n';
    return 0;
}

        虽说运用上述的方法已经可以完成本题了,但我们其实不额外添加一个状态也可以解决。 由上可得以下结论。

           •当n−1为奇数(n为偶数)时,向下走的次数可以为 \frac{n - 1}{2},也可以为 \frac{n - 1}{2} +1;

           •当n−1为偶数(n为奇数)时,向下走的次数只能为 \frac{n - 1}{2}

        基于向下走的次数、向右下走的次数限制不难发现以下情况。

           •当n−1为奇数(n为偶数)时,无论中间的路线是什么样的,最后的位置只有两种可能:

               ( n , 1 + \frac{n - 1}{2} ),( n , 1 + \frac{n - 1}{2} + 1 )。

          •当n为偶数时,无论中间的路线是什么样的,最后的位置只有一种可能:

               ( n , 1 + \frac{n - 1}{2} )。

        所以我们并不需要考虑从顶部走到底部时向下走的次数,只需要保证最后的位置正确即可。

        用dp[i][j]表示从(1,1)走到(i,j)的最大和并对其进行转移,那么答案就可以表示为:

参考代码如下【时间复杂度为O(n^{2})】 

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

const int N = 1e2 + 10;
int n, a[N][N], dp[N][N];

signed main() {
    cin >> n;

    for (int i = 1; i <= n; i++) {
        for (int j = 1; j <= i; j++) {
            cin >> a[i][j];
        }
    }

    dp[1][1] = a[1][1];

    for (int i = 2; i <= n; i++) {
        for (int j = 1; j <= i; j++) {
            dp[i][j] = max(dp[i - 1][j - 1], dp[i - 1][j]) + a[i][j];
        }
    }

    // 根据 n-1 的奇偶性输出:在满足向下走的次数与向右下走的次数相差不能超过 1 的条件下可能会到达的位置对应的 dp 值
    if ((n - 1) & 1) {
        cout << max(dp[n][1 + (n - 1) / 2], dp[n][1 + (n - 1) / 2 + 1]) << '\n';
    } else {
        cout << dp[n][1 + (n - 1) / 2] << '\n';
    }

    return 0;
}
解决子问题2:DFS模式 

        DFS的处理方法和动态规划的类似,有以下两种方法:

        (1)额外添加一个状态使得答案满足条件;

        (2)保证最后的位置正确使得答案满足条件。

        下面给出第二种方法的参考代码。

 参考代码如下

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

const int N = 1e2 + 10;
int n, a[N][N], res[N][N];

int dfs(int i, int j) {
    if (res[i][j]) return res[i][j]; // 如果 res[i][j] 不为 0,说明已经计算过,直接返回结果

    if (i == n) {
        if (n % 2 && j == n / 2 + 1) return a[i][j]; // n 为奇数且 j 为中间位置
        if (n % 2 == 0 && (j == n / 2 || j == n / 2 + 1)) return a[i][j]; // n 为偶数且 j 为中间两个位置之一
        return -10000000; // 位置不正确时,返回一个极大的负数
    }

    return res[i][j] = max(dfs(i + 1, j), dfs(i + 1, j + 1)) + a[i][j]; // 计算并存储结果
}

signed main() {
    cin >> n;

    for (int i = 1; i <= n; i++) {
        for (int j = 1; j <= i; j++) {
            cin >> a[i][j];
        }
    }

    cout << dfs(1, 1) << '\n';
    return 0;
}

二、砝码称重

【问题描述】

        你有一架天平和N个砝码,这N个砝码重量依次是W1,W2,...,WN。

        请你计算一共可以称出多少种不同的重量。注意砝码可以放在天平两边。

【输入格式】

        输入的第一行包含一个整数N。

        第二行包含N个整数:W1,W2,W3,...,WN。

【输出格式】

        输出一个整数表示答案。

【样例输入】

        

【样例输出】

        10

【样例说明】

        

【评测用例规模与规定】

        对于50% 的评测用例,1⩽ N ⩽15。

        对于所有评测用例,1⩽ N ⩽100,N 个砝码总重不超过100000。

解析:

        本题是道有限制的选择问题、背包问题的变形题。

        在本题中,题目给定了1个天平及n个砝码,每个砝码都有自己的重量。天平存在以下 3 种状态。

        (1)平衡。

        (2)向左倾斜。

        (3)向右倾斜。

        这3种状态分别可称出的重量:

        (1)0(忽略不计);

        (2)左侧的砝码重量−右侧的砝码重量;

        (3)右侧的砝码重量−左侧的砝码重量。

        显然,天平的状态只会受到两侧砝码的重量影响。对于每个砝码,它都有以下3种处理方式。

        (1)放在天平的左侧。

        (2)放在天平的右侧。

        (3)两侧都不放。

         那么,n个砝码就有3n种处理方式(情况)。

         在50%的评测用例中,1⩽n⩽15。当n=15时,315=14348907,数据规模为107 左右。

         因此,我们可以使用直接dfs“暴力”搜索出放置n个砝码的所有情况,并统计这些情况能够称出的不同重量的个数。

(1)dfs“暴力”搜索

参考代码如下【时间复杂度为O(3^{n})】

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

const int N = 1e2 + 10, M = 1e5 + 10;
int n, ans, w[N], vis[M]; // vis[x] = 1 表示可以称出重量 x

void dfs(int i, int left, int right) {
    if (i > n) {
        vis[max(left, right) - min(left, right)] = 1;
        return;
    }
    // 将第 i 个砝码放置在左边
    dfs(i + 1, left + w[i], right);
    // 将第 i 个砝码放置在右边
    dfs(i + 1, left, right + w[i]);
    // 两边都不放
    dfs(i + 1, left, right);
}

signed main() {
    cin >> n;

    for (int i = 1; i <= n; i++) {
        cin >> w[i];
    }

    dfs(1, 0, 0);

    for (int i = 1; i < M; i++) {
        if (vis[i]) {
            ans++;
        }
    }

    cout << ans << '\n';
    return 0;
}

        可当 1 ⩽ n ⩽100 时,还能用dfs搜索出所有情况吗?显然不行,因为当n=100时, 3^{100}会是个天文数字,计算机在有限的时间内是不可能搜索出所有情况的。

        那怎么办呢? 考虑用动态规划解决。 

(2)动态规划【正解】
        1. 设计状态数组

        按照常规的步骤,我们会设计一个状态数组dp[],其中dp[i]表示用前i个砝码所能称出 的不同重量的个数。

         这么设计看似合理,答案也可以用dp[n] 轻松表示,但略加思考后不难发现其存在一个 致命问题,即在状态转移的过程中,无法处理相同的重量被重复计算的情况。

         如何解决这个致命问题呢?我们只要将重量也设计在状态数组中,即设计一个boolean类 型的二维数组dp[][],其中 dp[i][j] = true 表示前 i 个砝码能通过天平称出重量 j,dp[i][j]= false 则表示前 i 个砝码不能通过天平称出重量j。

         由于n个砝码的总重量不超过100000,所以我们只要在求解完整个数组后,枚举dp[n][1∼ 100000],统计其中值为 true 的元素个数,即可得出 n 个砝码所能称出的不同重量的个数。

         到这里貌似没有什么问题。那么接下来,我们就来讨论一下如何求解dp[][]数组。

2. 初始状态

        起初,我们未在天平两侧放置任何砝码,天平它会处于一种平衡的状态。我们可以认为 此时天平称的重量为0,即dp[0][0]=true。

3. 推导转移方程

        事实上,天平所称出的重量总是会由重的一侧减去轻的一侧,即对于第i个砝码,若我 们将其放入天平较重的一侧,则它将使天平称出的重量增加wi;若将该砝码放入天平较轻的 一侧,则它将使天平称出的重量减少wi。例如,在我们处理完前i−1个砝码后,天平所称 出的重量为j,那么在处理完第i个砝码后,天平所能称出的重量将会根据对第i个砝码不 同的处理方式得到3种不同结果分别如下。

        (1)j+wi:将第i 个砝码放在较重的一侧。

        (2)j−wi:将第i 个砝码放在较轻的一侧。

        (3)j:两侧都不放。 因此,我们可推导出以下3种状态转移式:

        因此,我们可推导出以下3种状态转移式:

        若将3个状态转移式整合成一个,可得 

       完成状态转移式的推导。 值得注意的是,在进行状态转移的过程中,可能会出现 j < w[i] 的情况( j - w[i] < 0 )。若不进行处理,就会导致数组的越界,进而导致答案错误。

        因此,我们可以为所有重量添加一个偏移量offset(对于重量x,用x+offset来表示它), 如下图所示,使得∀j−w[i]+offset⩾0。

提示:添加上offset 后,dp[i][j] 的含义为前 i 个砝码能否通过天平称出重量 j−offset。

参考代码如下【时间复杂度为 O(n× n ∑ i=1 wi)】

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

const int N = 1e2 + 10, M = 1e5 + 10, offset = 1e5;
int n, ans, w[N], dp[N][2 * M];

signed main() {
    cin >> n;

    for (int i = 1; i <= n; i++) {
        cin >> w[i];
    }

    dp[0][0 + offset] = true;

    for (int i = 1; i <= n; i++) {
        for (int j = 0; j < M + offset; j++) {
            if (j - w[i] >= 0) dp[i][j] |= dp[i - 1][j - w[i]];
            dp[i][j] |= dp[i - 1][j + w[i]] | dp[i - 1][j];
        }
    }

    for (int i = 1 + offset; i < M + offset; i++) {
        if (dp[n][i]) ans++;
    }

    cout << ans << '\n';
    return 0;
}

 。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。。

下将以括号序列、组合数问题超级吧难的题为例子讲解动态规划

别忘了请点个赞+收藏+关注支持一下博主喵!!!!  !  !  !

关注博主,更多蓝桥杯nice题目静待更新:)

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

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

相关文章

AD软件如何快速切换三维视图,由2D切换至3D,以及如何恢复

在Altium Designer软件中&#xff0c;切换三维视图以及恢复二维视图的操作相对简单。以下是具体的步骤&#xff1a; 切换三维视图 在PCB设计界面中&#xff0c;2D切换3D&#xff0c;快捷键按住数字键盘中的“3”即可切换&#xff1b; 快捷键ctrlf&#xff08;或者vb快捷键也…

学习threejs,使用CubeCamera相机创建反光效果

&#x1f468;‍⚕️ 主页&#xff1a; gis分享者 &#x1f468;‍⚕️ 感谢各位大佬 点赞&#x1f44d; 收藏⭐ 留言&#x1f4dd; 加关注✅! &#x1f468;‍⚕️ 收录于专栏&#xff1a;threejs gis工程师 文章目录 一、&#x1f340;前言1.1 ☘️CubeCamera 立方体相机 二、…

长时间无事可做是个危险信号

小马加入的是技术开发部&#xff0c;专注于Java开发。团队里有一位姓隋的女同事&#xff0c;是唯一的web前端工程师&#xff0c;负责页面开发工作&#xff0c;比小马早两个月入职。公司的项目多以定制化OA系统为主&#xff0c;后端任务繁重&#xff0c;前端工作相对较少。在这样…

Llama模型分布式训练(微调)

1 常见大模型 1.1 参数量对照表 模型参数量发布时间训练的显存需求VGG-19143.68M2014~5 GB&#xff08;单 224x224 图像&#xff0c;batch_size32&#xff09;ResNet-15260.19M2015~7 GB&#xff08;单 224x224 图像&#xff0c;batch_size32&#xff09;GPT-2 117M117M2019~…

Linux 子进程 -- fork函数

子进程 什么是子进程? 子进程指的是由一个已经存在的进程&#xff08;称为父进程或父进程&#xff09;创建的进程. 如: OS (操作系统) 就可以当作是一个进程, 用来管理软硬件资源, 当我点击浏览器, 想让浏览器运行起来时, 实际上是由 OS 接收指令, 然后 OS 帮我们将浏览器运行…

DataLoade类与list ,iterator ,yield的用法

1 问题 探索DataLoader的属性&#xff0c;方法 Vscode中图标含意 list 与 iterator 的区别&#xff0c;尤其yield的用法 2 方法 知乎搜索DataLoader的属性&#xff0c;方法 pytorch基础的dataloader类是 from torch.utils.data.dataloader import Dataloader 其主要的参数如下&…

C++入门——“C++11-lambda”

引入 C11支持lambda表达式&#xff0c;lambda是一个匿名函数对象&#xff0c;它允许在函数体中直接定义。 一、初识lambda lambda的结构是&#xff1a;[ ] () -> 返回值类型 { }。从左到右依次是&#xff1a;捕捉列表 函数参数 -> 返回值类型 函数体。 以下是一段用lam…

【Linux网络编程】第二弹---Socket编程入门指南:从IP、端口号到传输层协议及编程接口全解析

✨个人主页&#xff1a; 熬夜学编程的小林 &#x1f497;系列专栏&#xff1a; 【C语言详解】 【数据结构详解】【C详解】【Linux系统编程】【Linux网络编程】 目录 1、Socket 编程预备 1.1、理解源 IP 和目的 IP 1.2、认识端口号 1.2.1、端口号范围划分 1.2.2、理解 &q…

《用Python实现3D动态旋转爱心模型》

简介 如果二维的爱心图案已经无法满足你的创意&#xff0c;那今天的内容一定适合你&#xff01;通过Python和matplotlib库&#xff0c;我们可以实现一个动态旋转的3D爱心模型&#xff0c;充满立体感和动感。# 实现代码&#xff08;完整代码底部名片私信&#xff09; 以下是完…

shell-函数调用进阶即重定向

shell-函数调用进阶 声明&#xff01; 学习视频来自B站up主 泷羽sec 有兴趣的师傅可以关注一下&#xff0c;如涉及侵权马上删除文章&#xff0c;笔记只是方便各位师傅的学习和探讨&#xff0c;文章所提到的网站以及内容&#xff0c;只做学习交流&#xff0c;其他均与本人以及泷…

【高等数学学习记录】微分中值定理

一、知识点 &#xff08;一&#xff09;罗尔定理 费马引理 设函数 f ( x ) f(x) f(x) 在点 x 0 x_0 x0​ 的某邻域 U ( x 0 ) U(x_0) U(x0​) 内有定义&#xff0c;并且在 x 0 x_0 x0​ 处可导&#xff0c;如果对任意的 x ∈ U ( x 0 ) x\in U(x_0) x∈U(x0​) &#xff0…

【vue-router】vue-router如何实现动态路由

✨✨ 欢迎大家来到景天科技苑✨✨ &#x1f388;&#x1f388; 养成好习惯&#xff0c;先赞后看哦~&#x1f388;&#x1f388; &#x1f3c6; 作者简介&#xff1a;景天科技苑 &#x1f3c6;《头衔》&#xff1a;大厂架构师&#xff0c;华为云开发者社区专家博主&#xff0c;…

Web前端技术浅谈CooKieAG网址漏洞与XSS攻防策略

随着互联网技术的飞速发展,Web前端开发已经成为构建网站和应用程序的重要环节。然而,Web前端开发中存在许多安全问题,这些问题不仅会影响用户体验,还可能给企业和个人带来严重的经济损失。但是web前端安全方面技术包含的东西较多&#xff0c;我们这里着重聊一聊关于XSS 的危害与…

关于VNC连接时自动断联的问题

在服务器端打开VNC Server的选项设置对话框&#xff0c;点左边的“Expert”&#xff08;专家&#xff09;&#xff0c;然后找到“IdleTimeout”&#xff0c;将数值设置为0&#xff0c;点OK关闭对话框。搞定。 注意,服务端有两个vnc服务,这俩都要设置ide timeout为0才行 附件是v…

51c自动驾驶~合集35

我自己的原文哦~ https://blog.51cto.com/whaosoft/12206500 #纯视觉方案的智驾在大雾天还能用吗&#xff1f; 碰上大雾天气&#xff0c;纯视觉方案是如何识别车辆和障碍物的呢&#xff1f; 如果真的是纯纯的&#xff0c;特头铁的那种纯视觉方案的话。 可以简单粗暴的理解为…

计算分数的浮点数值

计算分数的浮点数值 C语言代码C 代码Java代码Python代码 &#x1f490;The Begin&#x1f490;点点关注&#xff0c;收藏不迷路&#x1f490; 两个整数a和b分别作为分子和分母&#xff0c;既分数 a/b &#xff0c;求它的浮点数值&#xff08;双精度浮点数&#xff0c;保留小数点…

戴尔电脑安装centos7系统遇到的问题

1&#xff0c;找不到启动盘&#xff08;Operation System Loader signature found in SecureBoot exclusion database(‘dbx’).All bootable devices failed secure Boot Verification&#xff09; 关闭 Secure Boot&#xff08;推荐&#xff09;&#xff1a; 进入 BIOS/UEFI…

简单获取json预览

data: JSON 数据。 collapsedNodeLength: 对象或数组的长度超过此阈值时会折叠 deep: json路径深度超过此值时会折叠 showLineNumber: 显示左侧行号 showIcon: 显示图标。 virtual: 使用虚拟滚动 height: 使用虚拟滚动时列表的高度 itemHeight: 使用虚拟滚动时节点的高…

ChatGPT/AI辅助网络安全运营之-数据解压缩

在网络安全的世界中&#xff0c;经常会遇到各种压缩的数据&#xff0c;比如zip压缩&#xff0c;比如bzip2压缩&#xff0c;gzip压缩&#xff0c;xz压缩&#xff0c;7z压缩等。网络安全运营中需要对这些不同的压缩数据进行解压缩&#xff0c;解读其本意&#xff0c;本文将探索一…

Cookie概念和API

Cookie概念 Cookie在HTTP中它表示服务器送给客户端浏览器的小甜点。其实Cookie就是一个键和一个值构成的&#xff0c;随着服务器端的响应发送给客户端浏览器。然后客户端浏览器会把Cookie保存起来&#xff0c;当下一次再访问服务器时把Cookie再发送给服务器。 Cookie是由服务器…