CSDN每日一练 |『清理磁盘空间』『奇偶排序』『编号分组』2023-08-30

news2024/10/5 15:03:25

CSDN每日一练 |『清理磁盘空间』『奇偶排序』『编号分组』2023-08-30

  • 一、题目名称:清理磁盘空间
  • 二、题目名称:奇偶排序
  • 三、题目名称:奇偶排序
  • 四、题目名称:编号分组

一、题目名称:清理磁盘空间

时间限制:1000ms内存限制:256M

题目描述:

小明电脑空间满了,决定清空间。为了简化问题,小明列了他个人文件夹(/data)中所有末级文件路径和大小,挑选出总大小为 m 的删除方案,求所有删除方案中,删除操作次数最小是多少。 一次删除操作:删除文件或者删除文件夹。如果删除文件夹,那么该文件夹包含的文件都将被删除。 文件夹的大小:文件夹中所有末级文件大小之和

输入描述:

第一行输入 n (n <= 1000)和 m(m <= 1000),表示文件数量,和需要删除的大小 接下去有 n 行,每一行都是一个文件绝对路径(路径长度小于 100),和这个文件的大小(小于 1000)

输出描述:

输出所有删除方案中,删除操作次数最小是多少。如果找不到恰好删除的大小为 m 的方案,则打印 -1

🚩 示例:

✔️ 示例1:

输入
6 10
/data/movie/a.mp4 5
/data/movie/b.mp4 3
/data/movie/c.mp4 2
/data/movie/d.mp4 4
/data/picture/a.jpg 4
/data/picture/b.jpg 1

输出
2

🔔 解题思路:

首先将输入的文件按照大小从小到大进行排序,然后使用动态规划来解决问题。

定义一个二维数组dp,dp[i][j]表示前i个文件中删除大小为j的文件夹或文件的最小操作次数。

逐个文件进行状态转移。对于第 i 个文件,有两种情况:

如果删除了第 i 个文件,那么最小操作次数为 dp[i-1][j-size_i] + 1,其中 size_i 表示第 i 个文件的大小。

如果不删除第 i 个文件,那么最小操作次数为 dp[i-1][j]。

取这两种情况中的较小值。

最终答案即为 dp[n][m],如果 dp[n][m] 为无穷大,则表示不存在满足条件的删除方案。

代码1如下:

def minOperation(n, m, files):
    files.sort(key=lambda x: x[1])  # 按照文件大小排序

    # 初始化dp数组
    dp = [[float('inf')] * (m+1) for _ in range(n+1)]
    dp[0][0] = 0
    ##dp[i][j] 表示前 i 个文件中,构成大小为 j 的文件夹所需的最小操作次数

## 对于每个文件,可以选择将其放入目标文件夹或不放入背包
    for i in range(1, n+1):
        size_i = files[i-1][1]  # 第i个文件的大小
        for j in range(m+1):
            if j >= size_i:
                # 如果当前背包容量大于等于文件大小,可以选择将文件放入背包或者不放入背包
                dp[i][j] = min(dp[i-1][j-size_i] + 1, dp[i-1][j])
            else:
                # 当前背包容量小于文件大小,无法放入,只能选择不放入背包
                dp[i][j] = dp[i-1][j]

    if dp[n][m] == float('inf'):
        return -1
    else:
        return dp[n][m]  ##前 n 个文件构成大小为 m 的文件夹所需的最小操作次数

# 输入n和m
n, m = map(int, input().split())
files = []

# 输入每个文件的路径和大小
for _ in range(n):
    path, size = input().split()
    files.append((path, int(size)))

# 输出结果
print(minOperation(n, m, files))

在这里插入图片描述
代码2如下:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>

typedef struct {
    char path[100]; // 文件路径
    int size; // 文件大小
} File;

int minOperation(int n, int m, File* files) {
    int dp[m+1]; // 动态规划数组,dp[i] 表示大小为 i 的文件夹所需的最小操作次数
    dp[0] = 0; // 大小为 0 的文件夹不需要操作
    for (int i = 1; i <= m; ++i)
        dp[i] = -1; // 初始化为 -1,表示无法达到该大小的文件夹

    for (int i = 0; i < n; ++i) {
        for (int j = m; j >= files[i].size; --j) {
            // 如果可以从大小为 j-files[i].size 的文件夹转移过来
            if (dp[j-files[i].size] != -1) {
                // 如果当前大小为 j 的文件夹还未计算或转移次数更少,更新最小操作次数
                if (dp[j] == -1 || dp[j-files[i].size] + 1 < dp[j]) {
                    dp[j] = dp[j-files[i].size] + 1;
                }
            }
        }
    }

    return dp[m]; // 返回大小为 m 的文件夹所需的最小操作次数
}

int main() {
    int n, m;
    scanf("%d %d", &n, &m); // 输入文件夹数量和目标文件夹大小
    File* files = (File*) malloc(n * sizeof(File)); // 动态分配文件数组内存
    for (int i = 0; i < n; ++i)
        scanf("%s %d", files[i].path, &(files[i].size)); // 输入每个文件的路径和大小

    int result = minOperation(n, m, files); // 计算最小操作次数
    printf("%d\n", result); // 输出结果
    
    free(files); // 释放内存
    return 0;
}


在这里插入图片描述

其他大佬解法:

###建树,然后树上背包###

#include <bits/stdc++.h>
using namespace std;
const int maxn = 2010;
const int INF = 0x3f3f3f3f;
unordered_map<string, int> id;
vector<int> G[maxn];
int tot, n, m, w[maxn], dp[maxn][1010];
void dfs(int u)
{
    memset(dp[u], 0x3f, sizeof(dp[u]));
    dp[u][0] = 0;
    sort(G[u].begin(), G[u].end());
    G[u].erase(unique(G[u].begin(), G[u].end()), G[u].end());
    for (int v : G[u])
    {
        dfs(v);
        w[u] += w[v];
        for (int i = min(m, w[u]); i >= 0; --i)
        {
            for (int j = min(i, w[v]); j; --j)
            {
                dp[u][i] = min(dp[u][i], dp[v][j] + dp[u][i - j]);
            }
        }
    }
    if (w[u] <= m)
        dp[u][w[u]] = 1;
}
int main()
{
    cin >> n >> m;
    for (int i = 0, x; i < n; ++i)
    {
        string s;
        cin >> s >> x;
        s += "/";
        int len = s.size(), p = 0;
        string tmp = "";
        for (int j = 1; j < len; ++j)
        {
            tmp += s[j];
            if (s[j] == '/')
            {
                int now = id.count(tmp) ? id[tmp] : (id[tmp] = ++tot);
                G[p].emplace_back(now);
                p = now;
            }
        }
        w[p] = x;
    }
    dfs(0);
    if (dp[0][m] >= INF)
        dp[0][m] = -1;
    cout << dp[0][m] << endl;
    return 0;
}

在这里插入图片描述

二、题目名称:奇偶排序

时间限制:1000ms内存限制:256M

题目描述:

一个数组里有奇数有偶数(乱序),调整数组顺序使奇数位于偶数前面。(测试用例仅做参考,我们会根据代码质量进行评分)

输入描述:

第一行输入整数n。 第二行输入n个整数。

输出描述:

输出排序后的n个整数。

🚩示例:

✔️示例1

输入
4
2 3 1 23

输出
3 1 23 2

🔔 解题思路:

🚩 奇偶排序问题有两个题目。。

代码1如下:

# 输入整数 n,表示数组的大小
n = int(input())

# 从标准输入读取以空格分隔的整数,并转换为列表 arr
arr = list(map(int, input().split()))

# 使用列表推导式筛选奇数和偶数
# odd 列表存储所有奇数
odd = [num for num in arr if num % 2 == 1]

# even 列表存储所有偶数
even = [num for num in arr if num % 2 == 0]

# 将奇数列表和偶数列表拼接成一个新的列表 result,其中奇数在前,偶数在后
result = odd + even

# 将列表 result 中的每个元素转换为字符串,并使用空格作为分隔符拼接起来,然后通过 print() 函数输出
print(" ".join(map(str, result)))  # 或者使用 print(*result)

代码2如下:

# 输入n和数组元素
n = int(input())
nums = list(map(int, input().split()))

def oddEvenSort(nums):
    # 分别构建奇数列表和偶数列表
    odd_nums = []
    even_nums = []

    for num in nums:
        if num % 2 == 0:
            even_nums.append(num)  # 偶数放入偶数列表
        else:
            odd_nums.append(num)  # 奇数放入奇数列表

    sorted_nums = odd_nums + even_nums  # 将奇数列表和偶数列表合并

    return sorted_nums

# 输出排序后的数组
sorted_nums = oddEvenSort(nums)
print(' '.join(map(str, sorted_nums)))

在这里插入图片描述
代码3如下:

#include <stdio.h>
#include <stdlib.h>

// 奇偶排序函数
void oddEvenSort(int nums[], int n) {
    // 分别构建奇数列表和偶数列表
    int *odd_nums = (int *)malloc(n * sizeof(int));  // 申请存储奇数的数组内存
    int *even_nums = (int *)malloc(n * sizeof(int)); // 申请存储偶数的数组内存

    int odd_count = 0;  // 奇数的个数
    int even_count = 0; // 偶数的个数

    // 遍历原始数组,将奇数放入奇数列表,偶数放入偶数列表
    for (int i = 0; i < n; i++) {
        if (nums[i] % 2 == 0) {
            even_nums[even_count++] = nums[i];   // 偶数放入偶数列表
        } else {
            odd_nums[odd_count++] = nums[i];     // 奇数放入奇数列表
        }
    }

    // 将奇数列表和偶数列表合并到原始数组
    for (int i = 0; i < odd_count; i++) {
        nums[i] = odd_nums[i];
    }
    for (int i = 0; i < even_count; i++) {
        nums[i + odd_count] = even_nums[i];
    }

    free(odd_nums);   // 释放奇数列表内存
    free(even_nums);  // 释放偶数列表内存
}

int main() {
    int n;
    scanf("%d", &n);  // 输入元素个数

    int *nums = (int *)malloc(n * sizeof(int));  // 申请存储原始数组的内存
    for (int i = 0; i < n; i++) {
        scanf("%d", &nums[i]);  // 输入数组元素
    }

    oddEvenSort(nums, n);  // 调用奇偶排序函数进行排序

    // 输出排序后的数组
    for (int i = 0; i < n; i++) {
        printf("%d ", nums[i]);
    }
    printf("\n");

    free(nums);  // 释放原始数组内存

    return 0;
}

在这里插入图片描述
代码4如下:

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        int n = scanner.nextInt(); // 输入元素个数
        int[] nums = new int[n]; // 原始数组

        for (int i = 0; i < n; i++) {
            nums[i] = scanner.nextInt(); // 输入数组元素
        }

        int[] sorted_nums = oddEvenSort(nums); // 调用奇偶排序函数进行排序

        for (int i = 0; i < n; i++) {
            System.out.print(sorted_nums[i] + " "); // 输出排序后的数组
        }
    }

    /**
     * 将奇数和偶数分开并进行排序
     * @param nums 原始数组
     * @return 排序后的数组
     */
    public static int[] oddEvenSort(int[] nums) {
        int[] odd_nums = new int[nums.length]; // 存储奇数的数组
        int[] even_nums = new int[nums.length]; // 存储偶数的数组
        int odd_index = 0; // 奇数数组的索引
        int even_index = 0; // 偶数数组的索引

        for (int i = 0; i < nums.length; i++) {
            if (nums[i] % 2 == 0) {
                even_nums[even_index++] = nums[i]; // 偶数放入偶数数组
            } else {
                odd_nums[odd_index++] = nums[i]; // 奇数放入奇数数组
            }
        }

        int[] sorted_nums = new int[nums.length]; // 存储排序后的数组
        System.arraycopy(odd_nums, 0, sorted_nums, 0, odd_index); // 复制奇数数组到排序数组
        System.arraycopy(even_nums, 0, sorted_nums, odd_index, even_index); // 复制偶数数组到排序数组

        return sorted_nums;
    }
}

在这里插入图片描述

三、题目名称:奇偶排序

时间限制:1000ms内存限制:256M

题目描述:

给定一个存放整数的数组,重新排列数组使得数组左边为奇数,右边为偶数。(测试用例仅做参考,我们会根据代码质量进行评分)

输入描述:

第一行输入整数n。(1<=n<=1000)表示数组大小 第二行输入n个整数a.(1<=n<=100)

输出描述:

输出重排之后的数组。

🚩示例:

✔️示例1
输入
6
3 34 67 89 90 58

输出
3 67 89 34 90 58

🔔 解题思路:

奇数按从小到大的顺序排列并输出,偶数则保持输入顺序输出。

代码1如下:

# 输入整数 n,表示数组的大小
n = int(input())

# 从标准输入读取以空格分隔的整数,并转换为列表 arr
arr = list(map(int, input().split()))

# 使用列表推导式筛选奇数和偶数
# odd 列表存储所有奇数
odd = [num for num in arr if num % 2 == 1]

# even 列表存储所有偶数
even = [num for num in arr if num % 2 == 0]

# 将奇数列表和偶数列表拼接成一个新的列表 result,其中奇数在前,偶数在后
result = odd + even

# 将列表 result 中的每个元素转换为字符串,并使用空格作为分隔符拼接起来,然后通过 print() 函数输出
print(" ".join(map(str, result)))  # 或者使用 print(*result)

代码2如下:

# 输入n和数组元素
n = int(input())
nums = list(map(int, input().split()))

def oddEvenSort(nums):
    # 分别构建奇数列表和偶数列表
    odd_nums = []
    even_nums = []

    for num in nums:
        if num % 2 == 0:
            even_nums.append(num)  # 偶数放入偶数列表
        else:
            odd_nums.append(num)  # 奇数放入奇数列表

    sorted_nums = odd_nums + even_nums  # 将奇数列表和偶数列表合并

    return sorted_nums

# 输出排序后的数组
sorted_nums = oddEvenSort(nums)
print(' '.join(map(str, sorted_nums)))

在这里插入图片描述
代码3如下:

#include <stdio.h>
#include <stdlib.h>

// 奇偶排序函数
void oddEvenSort(int nums[], int n) {
    // 分别构建奇数列表和偶数列表
    int *odd_nums = (int *)malloc(n * sizeof(int));  // 申请存储奇数的数组内存
    int *even_nums = (int *)malloc(n * sizeof(int)); // 申请存储偶数的数组内存

    int odd_count = 0;  // 奇数的个数
    int even_count = 0; // 偶数的个数

    // 遍历原始数组,将奇数放入奇数列表,偶数放入偶数列表
    for (int i = 0; i < n; i++) {
        if (nums[i] % 2 == 0) {
            even_nums[even_count++] = nums[i];   // 偶数放入偶数列表
        } else {
            odd_nums[odd_count++] = nums[i];     // 奇数放入奇数列表
        }
    }

    // 将奇数列表和偶数列表合并到原始数组
    for (int i = 0; i < odd_count; i++) {
        nums[i] = odd_nums[i];
    }
    for (int i = 0; i < even_count; i++) {
        nums[i + odd_count] = even_nums[i];
    }

    free(odd_nums);   // 释放奇数列表内存
    free(even_nums);  // 释放偶数列表内存
}

int main() {
    int n;
    scanf("%d", &n);  // 输入元素个数

    int *nums = (int *)malloc(n * sizeof(int));  // 申请存储原始数组的内存
    for (int i = 0; i < n; i++) {
        scanf("%d", &nums[i]);  // 输入数组元素
    }

    oddEvenSort(nums, n);  // 调用奇偶排序函数进行排序

    // 输出排序后的数组
    for (int i = 0; i < n; i++) {
        printf("%d ", nums[i]);
    }
    printf("\n");

    free(nums);  // 释放原始数组内存

    return 0;
}

在这里插入图片描述
代码4如下:

import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        int n = scanner.nextInt(); // 输入元素个数
        int[] nums = new int[n]; // 原始数组

        for (int i = 0; i < n; i++) {
            nums[i] = scanner.nextInt(); // 输入数组元素
        }

        int[] sorted_nums = oddEvenSort(nums); // 调用奇偶排序函数进行排序

        for (int i = 0; i < n; i++) {
            System.out.print(sorted_nums[i] + " "); // 输出排序后的数组
        }
    }

    /**
     * 将奇数和偶数分开并进行排序
     * @param nums 原始数组
     * @return 排序后的数组
     */
    public static int[] oddEvenSort(int[] nums) {
        int[] odd_nums = new int[nums.length]; // 存储奇数的数组
        int[] even_nums = new int[nums.length]; // 存储偶数的数组
        int odd_index = 0; // 奇数数组的索引
        int even_index = 0; // 偶数数组的索引

        for (int i = 0; i < nums.length; i++) {
            if (nums[i] % 2 == 0) {
                even_nums[even_index++] = nums[i]; // 偶数放入偶数数组
            } else {
                odd_nums[odd_index++] = nums[i]; // 奇数放入奇数数组
            }
        }

        int[] sorted_nums = new int[nums.length]; // 存储排序后的数组
        System.arraycopy(odd_nums, 0, sorted_nums, 0, odd_index); // 复制奇数数组到排序数组
        System.arraycopy(even_nums, 0, sorted_nums, odd_index, even_index); // 复制偶数数组到排序数组

        return sorted_nums;
    }
}

在这里插入图片描述

四、题目名称:编号分组

时间限制:1000ms内存限制:256M

题目描述:

现欲对各有正整数编号的n个人进行分组,规定同组中不得出现两人编号乘积之开立方为正整数的情况,求构成最大分组的人数。

输入描述:

单行n个数字表示各人的编号(0<n<100000,每个数字的范围在1到2000000000之间)。

输出描述:

构成最大分组的人数d(d>=1)

🚩示例:

✔️示例1
输入
27 4 2 16

输出
3

🔔 提示:

仅限于两人编号乘积,而非一人本身的编号,或者是三人或更多人的编号乘积

🔔 解题思路:

首先,我们需要判断两个人的编号乘积的开立方是否为正整数。如果是正整数,则说明两个人不允许在同一组中。

其次,我们可以使用哈希表来记录每个人的编号及其出现的次数。然后遍历哈希表,对于每个编号,计算其开立方并判断是否为整数,如果是整数,则该编号不能与其他编号在同一组中。

最后,统计剩余可分配到同一组的人数,即为最大分组的人数。

代码1如下:

使用集合和列表来实现,遍历每对编号,计算其乘积,并判断乘积的立方根是否为整数。如果是整数,则将两个编号都加入一个集合invalid_nums,表示它们不满足条件。

最后,通过计算总人数减去不满足条件的编号数,即可得到最大分组的人数。

# 读取输入
nums = list(map(int, input().split()))

# 使用集合存储不满足条件的编号
invalid_nums = set()

# 遍历每对编号,判断其乘积的立方根是否为整数
for i in range(len(nums)):
    for j in range(i+1, len(nums)):
        product = nums[i] * nums[j]
        if int(product ** (1/3)) ** 3 == product:
            invalid_nums.add(nums[i])     # 将第一个编号加入不满足条件的集合
            invalid_nums.add(nums[j])     # 将第二个编号加入不满足条件的集合

# 计算最大分组的人数
maxGroup = len(nums) - len(invalid_nums)

# 输出结果
print(maxGroup)

在这里插入图片描述

代码2如下:

import math

# 读取输入
nums = list(map(int, input().split()))

# 定义函数:获取最大分组的人数
def getMaxGroup(nums):
    counts = {}  # 创建一个空的字典,用于记录每个编号出现的次数
    for num in nums:
        if num in counts:       # 如果当前编号已经在字典中,则将其出现次数加1
            counts[num] += 1
        else:
            counts[num] = 1     # 否则将其加入字典,并设置出现次数为1
            
    maxGroup = 0                # 初始化最大分组人数为0
    for num in counts:
        isValid = True          # 标记当前编号是否与其他编号乘积的立方根为整数
        for otherNum in counts:
            if num == otherNum:     # 如果是同一个编号,则跳过比较
                continue
            if math.isqrt(num * otherNum) ** 3 == num * otherNum:   # 判断两个编号乘积的立方根是否为整数
                isValid = False     # 如果是整数,则将标记置为False,并跳出循环
                break
        if isValid:           # 如果当前编号不与任何其他编号满足条件,则将其出现次数累加到最大分组人数上
            maxGroup += counts[num]
    
    return maxGroup      # 返回最大分组人数


# 计算最大分组的人数
maxGroup = getMaxGroup(nums)

# 输出结果
print(maxGroup)


在这里插入图片描述

代码3如下:

# 读取输入
n = input()

def max_group(n):
    nums = n.split()  # 将输入的数字分割成列表
    groups = {}  # 存储分组情况
    for num in nums:
        num = int(num)
        for group in groups.values():
            flag = True
            for member in group:
                if (num * member) ** (1/3) == int((num * member) ** (1/3)):
                    flag = False
                    break
            if not flag:
                continue
            group.append(num)
            break
        else:
            groups[len(groups)] = [num]  # 加入新的分组
    max_group_size = max(len(group) for group in groups.values())  # 统计最大分组人数
    return max_group_size
    
result = max_group(n)
print(result)

在这里插入图片描述
代码4如下:

#include <stdio.h>
#include <math.h>
#define MAX_SIZE 100

int getMaxGroup(int nums[], int n) {
    int counts[MAX_SIZE] = {0};
    int maxGroup = 0;
    
    // 统计每个编号的出现次数
    for (int i = 0; i < n; i++) {
        counts[nums[i]]++;
    }
    
    for (int i = 0; i < n; i++) {
        int isValid = 1;
        // 判断当前编号是否与其他编号乘积的立方根为整数
        for (int j = 0; j < n; j++) {
            if (i == j) {
                continue;
            }
            if (pow(nums[i] * nums[j], 1.0 / 3) - (int)(pow(nums[i] * nums[j], 1.0 / 3)) == 0) {
                isValid = 0;
                break;
            }
        }
        if (isValid) {
            maxGroup += counts[nums[i]];
        }
    }
    
    return maxGroup;
}

int main() {
    int nums[MAX_SIZE];
    int n;

    // 读取输入
    scanf("%d", &n);
    for (int i = 0; i < n; i++) {
        scanf("%d", &nums[i]);
    }

    // 计算最大分组的人数
    int maxGroup = getMaxGroup(nums, n);

    // 输出结果
    printf("%d\n", maxGroup);

    return 0;
}

在这里插入图片描述

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

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

相关文章

e与phi不互素的情况

情况一&#xff1a;e较大且与(p-1)或(q-1)中任意一个不互素 例题&#xff1a;moeCTF2022---Signin 题目源码&#xff1a; from Crypto.Util.number import * from secret import flag mbytes_to_long(flag) pgetPrime(512) qgetPrime(512) print(p,p) print(q,q) np*q e65537…

DEFORMABLE DETR: DEFORMABLE TRANSFORMERS FOR END-TO-END OBJECT DETECTION 论文精读笔记

DEFORMABLE DETR DEFORMABLE DETR: DEFORMABLE TRANSFORMERS FOR END-TO-END OBJECT DETECTION 参考&#xff1a;AI-杂货铺-Transformer跨界CV又一佳作&#xff01;Deformable DETR&#xff1a;超强的小目标检测算法&#xff01; 摘要 摘要部分&#xff0c;作者主要说明了如…

Mybatis1.8 删除一行数据

1.8 删除一行数据 1.8.1 编写接口方法1.8.2 编写SQL语句1.8.3 编写测试方法 如上图所示&#xff0c;每行数据后面都有一个 删除 按钮&#xff0c;当用户点击了该按钮&#xff0c;就会将改行数据删除掉。那我们就需要思考&#xff0c;这种删除是根据什么进行删除呢&#xff1f;是…

HttpClient 绕过证书验证- sun.security.validator.ValidatorException: PKIX

sun.security.validator.ValidatorException: PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find valid certification path to requested target 问题 package com.example.demo.test;import com.alibaba.fastjson2.JS…

MySQL的备份与恢复以及日志管理

目录 一、数据备份的重要性 二、数据库备份的分类 1、物理备份 2、逻辑备份 &#xff08;1&#xff09;完全备份&#xff1a;每次对数据进行完整的备份 &#xff08;2&#xff09;差异备份&#xff1a;备份自从上次完全备份之后被修改的过文件 &#xff08;3&#xff09…

优化爬虫请求:如何选择合适的爬虫ip轮换策略?

在进行爬虫任务时&#xff0c;使用隧道爬虫ip并采用合适的轮换策略可以提高稳定性和效率。选择合适的隧道爬虫ip轮换策略可以优化您的爬虫请求过程。 1、考量目标网站特点 不同网站对于频繁请求可能有不同限制或反爬机制。 了解目标网站是否存在IP封禁、验证码等问题&#xff…

初创公司如何选择小型办公室

初创公司寻找小型办公室时&#xff0c;有多种选择。不同的办公室类型具有不同的租金成本、交通便利程度和对公司发展的影响。本文将比较几种不同的小型办公室&#xff0c;为初创公司提供选择建议。 共享办公空间 共享办公空间是一种适合初创公司和自由职业者的办公室类型。这种…

Mybatis1.10 Mybatis参数传递

1.10 Mybatis参数传递 1.10.1 多个参数1.10.2 单个参数 Mybatis 接口方法中可以接收各种各样的参数&#xff0c;如下&#xff1a; 多个参数单个参数&#xff1a;单个参数又可以是如下类型 POJO 类型Map 集合类型Collection 集合类型List 集合类型Array 类型其他类型 1.10.1 …

Kubernetes技术-Kubernetes集群环境搭建准备

1.搭建环境规划 在搭建k8s的时候可以分为两种: 单master集群,故名思意,只有一个master管理节点和多个node节点。如下图所示: 多master集群,故名思意,有多个master管理节点和多个node节点。如下图所示: 2.服务器硬件要求 (1).测试环境要求(教学、研究等环境) Master节点:至…

《Kali渗透基础》15. WEB 渗透

kali渗透 1&#xff1a;WEB 技术1.1&#xff1a;WEB 攻击面1.2&#xff1a;HTTP 协议基础1.3&#xff1a;AJAX1.4&#xff1a;WEB Service 2&#xff1a;扫描工具2.1&#xff1a;HTTrack2.2&#xff1a;Nikto2.3&#xff1a;Skipfish2.4&#xff1a;Arachni2.5&#xff1a;OWAS…

YOLOv5 7.0添加ACmix

ACmix 论文地址&#xff1a;On the Integration of Self-Attention and Convolution ACmix探讨了卷积和自注意力这两种强大技术之间的关系&#xff0c;并将两者整合在一起&#xff0c;同时享有双份好处&#xff0c;并显著降低计算开销&#xff0c;可助力现有主干涨点&#xff…

php对接AWS S3云存储,上传S3及访问权限问题

首先先下载sdk包 https://docs.aws.amazon.com/zh_cn/sdk-for-php/v3/developer-guide/getting-started_installation.html S3创建存储桶 去安全凭证-》创建访问秘钥 创建的时候会提示&#xff0c;主账号创建不安全&#xff0c;这个时候我们需要创建一个IAM账号来创建秘钥 创…

ES6中的箭头函数(arrow function)与普通函数的不同之处

聚沙成塔每天进步一点点 ⭐ 专栏简介⭐ 语法简洁⭐ 没有自己的this⭐ 写在最后 ⭐ 专栏简介 前端入门之旅&#xff1a;探索Web开发的奇妙世界 记得点击上方或者右侧链接订阅本专栏哦 几何带你启航前端之旅 欢迎来到前端入门之旅&#xff01;这个专栏是为那些对Web开发感兴趣、…

可以翻页的电子画册制作指南

​电子画册是一种创新的方式&#xff0c;可以将传统的纸质画册转化为数字化的形式&#xff0c;并且具备翻页的功能。它不仅可以提供更好的阅读体验&#xff0c;还可以方便地分享给他人。 1.选择制作工具&#xff1a; 有许多在线平台和软件可以帮助你制作电子画册&#xff0c;比…

小程序数据导出文件

小程序josn数据生成excel文件 先从下载传送门将xlsx.mini.min.js拷贝下来&#xff0c;新建xlsx.js文件放入小程序项目文件夹下。 const XLSX require(./xlsx)//在需要用的页面中引入// 定义导出 Excel 报表的方法exportData() {const that thislet newData [{time:2021,val…

全球领先、柔性低功耗?京东方独家供应OPPO折叠屏,首发值得一试

京东方作为全球领先的显示技术创新企业&#xff0c;为OPPO提供的折叠屏手机和智能手表屏幕&#xff0c;拥有先进的技术和优质的显示效果。京东方的柔性折叠低功耗解决方案不仅能够实现屏幕的弯折&#xff0c;还能在折叠状态下保持低功耗&#xff0c;使设备的续航时间得到极大增…

windows10上搭建caffe以及踩到的坑

对动作捕捉的几篇论文感兴趣&#xff0c;想复现一下&#xff0c;需要caffe环境就折腾了下&#xff01;转模型需要python 2.7环境&#xff0c;我顺便也弄了&#xff01;&#xff01;&#xff01; 1. 环境 Windows10 RTX2080TI 11G Anaconda Python2.7 visual studio 2013 cuda…

第三方软件检测机构有哪些资质,2023年软件测评公司推荐

软件第三方测试报告 伴随着软件行业的蓬勃发展&#xff0c;软件测试也迎来了热潮&#xff0c;但是国内的软件测试行业存在着测试入行门槛低、测试投入少、测试人员专业性不足等问题&#xff0c;这些问题不但会阻碍软件测试行业的良性发展&#xff0c;而且难以保证软件产品的质…

魏副业而战:开学季,闲鱼卖什么好?

我是魏哥&#xff0c;与其躺平&#xff0c;不如魏副业而战&#xff01; 现在八月底了&#xff0c;意味着暑假结束&#xff0c;新的学期将要开始。 作为闲鱼卖家&#xff0c;可顺势布局一下。 那卖什么好呢&#xff1f; 开学季嘛&#xff0c;卖学习相关的&#xff0c;例如&a…

1.docker打包前后端项目 2.将虚拟机设置为固定ip 3.WARNING: IPv4 forwarding is disabled. Networking will not work

打包后端项目 1.查看防火墙状态 netsh advfirewall show allprofiles 显示防火墙的当前状态和配置信息。您将在输出中看到每个配置文件&#xff08;公用、专用和域&#xff09;的状态。 2.关闭防火墙 netsh advfirewall set allprofiles state off 将关闭所有配置文件&#…