14天速成PAT-BASIC基础知识!

两周关于PAT的基础学习计划。

Day 1: 基本语法和输入输出
  • 知识点

    • 数据类型(int, long, float, double, char)
    • 变量声明和初始化
    • 输入输出函数(scanf, printf)
    • 控制结构(if-else, switch, for, while, do-while)
  • 代码练习

    • 编写一个程序,读取两个整数并输出它们的和。
    • 编写一个程序,根据用户输入的成绩判断是否及格(60分以上)。
    • 编写一个程序,使用for循环打印1到100的所有整数。
#include <stdio.h>

int main() {
    int a, b;
    scanf("%d %d", &a, &b);
    printf("Sum: %d\n", a + b);
    return 0;
}

// 判断成绩是否及格
#include <stdio.h>

int main() {
    int score;
    scanf("%d", &score);
    if (score >= 60) {
        printf("Pass\n");
    } else {
        printf("Fail\n");
    }
    return 0;
}

// 打印1到100
#include <stdio.h>

int main() {
    for (int i = 1; i <= 100; ++i) {
        printf("%d ", i);
    }
    return 0;
}
Day 2: 数组和字符串
  • 知识点

    • 一维数组的声明、初始化和访问
    • 字符串的基本操作(strlen, strcpy, strcat, strcmp, strstr)
  • 代码练习

    • 编写一个程序,读取一个数组并输出其最大值。
    • 编写一个程序,读取两个字符串并比较它们是否相等。
    • 编写一个程序,将两个字符串连接起来并输出结果。
#include <stdio.h>
#include <string.h>

int main() {
    int arr[5];
    for (int i = 0; i < 5; ++i) {
        scanf("%d", &arr[i]);
    }
    int max = arr[0];
    for (int i = 1; i < 5; ++i) {
        if (arr[i] > max) {
            max = arr[i];
        }
    }
    printf("Max: %d\n", max);
    return 0;
}

// 比较两个字符串
#include <stdio.h>
#include <string.h>

int main() {
    char str1[100], str2[100];
    scanf("%s %s", str1, str2);
    if (strcmp(str1, str2) == 0) {
        printf("Equal\n");
    } else {
        printf("Not Equal\n");
    }
    return 0;
}

// 连接两个字符串
#include <stdio.h>
#include <string.h>

int main() {
    char str1[100], str2[100], result[200];
    scanf("%s %s", str1, str2);
    strcpy(result, str1);
    strcat(result, str2);
    printf("Result: %s\n", result);
    return 0;
}
Day 3: 函数和指针
  • 知识点

    • 函数的定义和调用
    • 参数传递(值传递和指针传递)
    • 指针的基本概念和用法
  • 代码练习

    • 编写一个函数,计算两个整数的乘积并返回结果。
    • 编写一个函数,交换两个整数的值(使用指针)。
    • 编写一个函数,查找数组中的最大值(使用指针)。
#include <stdio.h>

int multiply(int a, int b) {
    return a * b;
}

void swap(int *a, int *b) {
    int temp = *a;
    *a = *b;
    *b = temp;
}

int find_max(int *arr, int size) {
    int max = arr[0];
    for (int i = 1; i < size; ++i) {
        if (arr[i] > max) {
            max = arr[i];
        }
    }
    return max;
}

int main() {
    int a = 5, b = 10;
    printf("Product: %d\n", multiply(a, b));
  
    swap(&a, &b);
    printf("After swap: a = %d, b = %d\n", a, b);

    int arr[] = {1, 2, 3, 4, 5};
    int size = sizeof(arr) / sizeof(arr[0]);
    printf("Max in array: %d\n", find_max(arr, size));
    return 0;
}
Day 4: 结构体和文件操作
  • 知识点

    • 结构体的定义和使用
    • 文件的打开、读写和关闭(fopen, fscanf, fprintf, fclose)
  • 代码练习

    • 定义一个学生结构体,包含姓名和成绩,并编写一个程序读取多个学生的信息并输出。
    • 编写一个程序,从文件中读取数据并处理。
#include <stdio.h>
#include <string.h>

struct Student {
    char name[50];
    int score;
};

void read_students(struct Student students[], int n) {
    for (int i = 0; i < n; ++i) {
        scanf("%s %d", students[i].name, &students[i].score);
    }
}

void print_students(struct Student students[], int n) {
    for (int i = 0; i < n; ++i) {
        printf("Name: %s, Score: %d\n", students[i].name, students[i].score);
    }
}

int main() {
    struct Student students[3];
    read_students(students, 3);
    print_students(students, 3);
    return 0;
}

// 从文件中读取数据
#include <stdio.h>

int main() {
    FILE *file = fopen("data.txt", "r");
    if (file == NULL) {
        printf("File not found!\n");
        return 1;
    }

    int num;
    while (fscanf(file, "%d", &num) != EOF) {
        printf("%d\n", num);
    }

    fclose(file);
    return 0;
}
Day 5: 动态内存分配
  • 知识点

    • malloc, calloc, realloc, free
    • 动态数组的创建和管理
  • 代码练习

    • 编写一个程序,动态分配一个数组并读取用户输入的数据。
    • 编写一个程序,动态分配一个二维数组并进行基本操作。
#include <stdio.h>
#include <stdlib.h>

int main() {
    int n;
    printf("Enter the number of elements: ");
    scanf("%d", &n);

    int *arr = (int *)malloc(n * sizeof(int));
    if (arr == NULL) {
        printf("Memory allocation failed!\n");
        return 1;
    }

    for (int i = 0; i < n; ++i) {
        scanf("%d", &arr[i]);
    }

    for (int i = 0; i < n; ++i) {
        printf("%d ", arr[i]);
    }
    printf("\n");

    free(arr);
    return 0;
}

// 动态分配二维数组
#include <stdio.h>
#include <stdlib.h>

int main() {
    int rows, cols;
    printf("Enter the number of rows and columns: ");
    scanf("%d %d", &rows, &cols);

    int **matrix = (int **)malloc(rows * sizeof(int *));
    for (int i = 0; i < rows; ++i) {
        matrix[i] = (int *)malloc(cols * sizeof(int));
    }

    for (int i = 0; i < rows; ++i) {
        for (int j = 0; j < cols; ++j) {
            scanf("%d", &matrix[i][j]);
        }
    }

    for (int i = 0; i < rows; ++i) {
        for (int j = 0; j < cols; ++j) {
            printf("%d ", matrix[i][j]);
        }
        printf("\n");
    }

    for (int i = 0; i < rows; ++i) {
        free(matrix[i]);
    }
    free(matrix);
    return 0;
}
Day 6: 排序算法
  • 知识点

    • 冒泡排序
    • 选择排序
    • 插入排序
    • 快速排序(qsort)
  • 代码练习

    • 实现冒泡排序、选择排序和插入排序。
    • 使用qsort对数组进行排序。
#include <stdio.h>
#include <stdlib.h>

void bubble_sort(int arr[], int n) {
    for (int i = 0; i < n - 1; ++i) {
        for (int j = 0; j < n - i - 1; ++j) {
            if (arr[j] > arr[j + 1]) {
                int temp = arr[j];
                arr[j] = arr[j + 1];
                arr[j + 1] = temp;
            }
        }
    }
}

void selection_sort(int arr[], int n) {
    for (int i = 0; i < n - 1; ++i) {
        int min_index = i;
        for (int j = i + 1; j < n; ++j) {
            if (arr[j] < arr[min_index]) {
                min_index = j;
            }
        }
        int temp = arr[i];
        arr[i] = arr[min_index];
        arr[min_index] = temp;
    }
}

void insertion_sort(int arr[], int n) {
    for (int i = 1; i < n; ++i) {
        int key = arr[i];
        int j = i - 1;
        while (j >= 0 && arr[j] > key) {
            arr[j + 1] = arr[j];
            --j;
        }
        arr[j + 1] = key;
    }
}

int compare(const void *a, const void *b) {
    return (*(int *)a - *(int *)b);
}

int main() {
    int arr[] = {5, 3, 8, 1, 2};
    int n = sizeof(arr) / sizeof(arr[0]);

    // Bubble Sort
    int arr_bubble[n];
    for (int i = 0; i < n; ++i) {
        arr_bubble[i] = arr[i];
    }
    bubble_sort(arr_bubble, n);
    printf("Bubble Sort: ");
    for (int i = 0; i < n; ++i) {
        printf("%d ", arr_bubble[i]);
    }
    printf("\n");

    // Selection Sort
    int arr_selection[n];
    for (int i = 0; i < n; ++i) {
        arr_selection[i] = arr[i];
    }
    selection_sort(arr_selection, n);
    printf("Selection Sort: ");
    for (int i = 0; i < n; ++i) {
        printf("%d ", arr_selection[i]);
    }
    printf("\n");

    // Insertion Sort
    int arr_insertion[n];
    for (int i = 0; i < n; ++i) {
        arr_insertion[i] = arr[i];
    }
    insertion_sort(arr_insertion, n);
    printf("Insertion Sort: ");
    for (int i = 0; i < n; ++i) {
        printf("%d ", arr_insertion[i]);
    }
    printf("\n");

    // Quick Sort
    int arr_quick[n];
    for (int i = 0; i < n; ++i) {
        arr_quick[i] = arr[i];
    }
    qsort(arr_quick, n, sizeof(int), compare);
    printf("Quick Sort: ");
    for (int i = 0; i < n; ++i) {
        printf("%d ", arr_quick[i]);
    }
    printf("\n");

    return 0;
}
Day 7: 递归和回溯
  • 知识点

    • 递归的基本概念
    • 回溯算法(八皇后问题、全排列)
  • 代码练习

    • 实现阶乘函数(递归)
    • 实现斐波那契数列(递归)
    • 解决八皇后问题(回溯)
#include <stdio.h>

int factorial(int n) {
    if (n == 0 || n == 1) {
        return 1;
    }
    return n * factorial(n - 1);
}

int fibonacci(int n) {
    if (n <= 1) {
        return n;
    }
    return fibonacci(n - 1) + fibonacci(n - 2);
}

int board[8][8];

int is_safe(int row, int col) {
    for (int i = 0; i < col; ++i) {
        if (board[row][i]) {
            return 0;
        }
    }

    for (int i = row, j = col; i >= 0 && j >= 0; --i, --j) {
        if (board[i][j]) {
            return 0;
        }
    }

    for (int i = row, j = col; i < 8 && j >= 0; ++i, --j) {
        if (board[i][j]) {
            return 0;
        }
    }

    return 1;
}

int solve_n_queens(int col) {
    if (col >= 8) {
        return 1;
    }

    for (int i = 0; i < 8; ++i) {
        if (is_safe(i, col)) {
            board[i][col] = 1;
            if (solve_n_queens(col + 1)) {
                return 1;
            }
            board[i][col] = 0;
        }
    }

    return 0;
}

void print_board() {
    for (int i = 0; i < 8; ++i) {
        for (int j = 0; j < 8; ++j) {
            printf("%d ", board[i][j]);
        }
        printf("\n");
    }
    printf("\n");
}

int main() {
    int n = 5;
    printf("Factorial of %d: %d\n", n, factorial(n));
    printf("Fibonacci of %d: %d\n", n, fibonacci(n));

    if (solve_n_queens(0)) {
        print_board();
    } else {
        printf("No solution exists.\n");
    }

    return 0;
}
Day 8: 数学问题
  • 知识点

    • 素数筛法(埃氏筛法)
    • 最大公约数(欧几里得算法)
    • 组合数计算
  • 代码练习

    • 实现埃氏筛法求素数
    • 实现欧几里得算法求最大公约数
    • 计算组合数
#include <stdio.h>
#include <stdbool.h>

const int MAXN = 1000000;

bool is_prime[MAXN + 1];

void sieve() {
    for (int i = 0; i <= MAXN; ++i) {
        is_prime[i] = true;
    }
    is_prime[0] = is_prime[1] = false;
    for (int i = 2; i * i <= MAXN; ++i) {
        if (is_prime[i]) {
            for (int j = i * i; j <= MAXN; j += i) {
                is_prime[j] = false;
            }
        }
    }
}

int gcd(int a, int b) {
    if (b == 0) {
        return a;
    }
    return gcd(b, a % b);
}

long long combination(int n, int k) {
    if (k > n - k) {
        k = n - k;
    }
    long long result = 1;
    for (int i = 0; i < k; ++i) {
        result *= (n - i);
        result /= (i + 1);
    }
    return result;
}

int main() {
    sieve();
    for (int i = 0; i < 20; ++i) {
        if (is_prime[i]) {
            printf("%d ", i);
        }
    }
    printf("\n");

    int a = 48, b = 18;
    printf("GCD of %d and %d: %d\n", a, b, gcd(a, b));

    int n = 5, k = 3;
    printf("Combination C(%d, %d): %lld\n", n, k, combination(n, k));

    return 0;
}
Day 9: 字符串处理进阶
  • 知识点

    • 字符串分割(strtok)
    • 字符串转换(atoi, itoa)
    • 字符串逆序
  • 代码练习

    • 实现字符串分割
    • 实现字符串到整数的转换
    • 实现字符串逆序
#include <stdio.h>
#include <string.h>
#include <stdlib.h>

void split_string(const char *str, const char *delim, char *result[]) {
    char *token = strtok((char *)str, delim);
    int index = 0;
    while (token != NULL) {
        result[index++] = token;
        token = strtok(NULL, delim);
    }
}

int string_to_int(const char *str) {
    int result = 0;
    int sign = 1;
    int i = 0;

    if (str[0] == '-') {
        sign = -1;
        i = 1;
    }

    for (; str[i] != '\0'; ++i) {
        result = result * 10 + (str[i] - '0');
    }

    return result * sign;
}

void reverse_string(char *str) {
    int len = strlen(str);
    for (int i = 0; i < len / 2; ++i) {
        char temp = str[i];
        str[i] = str[len - i - 1];
        str[len - i - 1] = temp;
    }
}

int main() {
    const char *str = "Hello,World,This,Is,PAT";
    char *result[10];
    split_string(str, ",", result);
    for (int i = 0; result[i] != NULL; ++i) {
        printf("%s\n", result[i]);
    }

    const char *num_str = "-12345";
    int num = string_to_int(num_str);
    printf("String to Int: %d\n", num);

    char str_reverse[] = "PAT";
    reverse_string(str_reverse);
    printf("Reversed String: %s\n", str_reverse);

    return 0;
}
Day 10: 模拟题训练
  • 知识点

    • 综合运用前面所学的知识点
    • 解决实际问题
  • 代码练习

    • 从PAT Basic历年真题中挑选几个题目进行练习。
// 例题1:统计字母频率
#include <stdio.h>
#include <string.h>

int main() {
    char str[1000];
    int freq[26] = {0};

    scanf("%s", str);

    for (int i = 0; str[i] != '\0'; ++i) {
        if (str[i] >= 'a' && str[i] <= 'z') {
            freq[str[i] - 'a']++;
        } else if (str[i] >= 'A' && str[i] <= 'Z') {
            freq[str[i] - 'A']++;
        }
    }

    for (int i = 0; i < 26; ++i) {
        if (freq[i] > 0) {
            printf("%c: %d\n", 'a' + i, freq[i]);
        }
    }

    return 0;
}

// 例题2:矩阵转置
#include <stdio.h>

int main() {
    int rows, cols;
    scanf("%d %d", &rows, &cols);

    int matrix[100][100];
    for (int i = 0; i < rows; ++i) {
        for (int j = 0; j < cols; ++j) {
            scanf("%d", &matrix[i][j]);
        }
    }

    for (int i = 0; i < cols; ++i) {
        for (int j = 0; j < rows; ++j) {
            printf("%d ", matrix[j][i]);
        }
        printf("\n");
    }

    return 0;
}
Day 11: 模拟题训练
  • 知识点

    • 继续综合运用前面所学的知识点
    • 解决实际问题
  • 代码练习

    • 从PAT Basic历年真题中再挑选几个题目进行练习。
// 例题3:查找子串
#include <stdio.h>
#include <string.h>

int main() {
    char str[1000], sub[100];
    scanf("%s %s", str, sub);

    char *pos = strstr(str, sub);
    if (pos != NULL) {
        printf("Found at position: %ld\n", pos - str);
    } else {
        printf("Not Found\n");
    }

    return 0;
}

// 例题4:最大子数组和
#include <stdio.h>

int max_subarray_sum(int arr[], int n) {
    int max_so_far = arr[0];
    int current_max = arr[0];

    for (int i = 1; i < n; ++i) {
        current_max = (current_max + arr[i] > arr[i]) ? current_max + arr[i] : arr[i];
        max_so_far = (max_so_far > current_max) ? max_so_far : current_max;
    }

    return max_so_far;
}

int main() {
    int n;
    scanf("%d", &n);
    int arr[1000];
    for (int i = 0; i < n; ++i) {
        scanf("%d", &arr[i]);
    }

    printf("Max Subarray Sum: %d\n", max_subarray_sum(arr, n));

    return 0;
}
Day 12: 模拟题训练
  • 知识点

    • 继续综合运用前面所学的知识点
    • 解决实际问题
  • 代码练习

    • 从PAT Basic历年真题中再挑选几个题目进行练习。
// 例题5:字符串压缩
#include <stdio.h>
#include <string.h>

void compress_string(const char *input, char *output) {
    int len = strlen(input);
    int count = 1;
    int j = 0;

    for (int i = 0; i < len; ++i) {
        if (i + 1 < len && input[i] == input[i + 1]) {
            count++;
        } else {
            output[j++] = input[i];
            if (count > 1) {
                sprintf(output + j, "%d", count);
                j += strlen(output + j);
            }
            count = 1;
        }
    }
    output[j] = '\0';
}

int main() {
    char input[1000], output[1000];
    scanf("%s", input);

    compress_string(input, output);
    printf("Compressed: %s\n", output);

    return 0;
}

// 例题6:最长公共子序列
#include <stdio.h>
#include <string.h>

int lcs_length(const char *X, const char *Y, int m, int n) {
    int L[m + 1][n + 1];

    for (int i = 0; i <= m; ++i) {
        for (int j = 0; j <= n; ++j) {
            if (i == 0 || j == 0) {
                L[i][j] = 0;
            } else if (X[i - 1] == Y[j - 1]) {
                L[i][j] = L[i - 1][j - 1] + 1;
            } else {
                L[i][j] = (L[i - 1][j] > L[i][j - 1]) ? L[i - 1][j] : L[i][j - 1];
            }
        }
    }

    return L[m][n];
}

int main() {
    char X[100], Y[100];
    scanf("%s %s", X, Y);

    int m = strlen(X);
    int n = strlen(Y);

    printf("Length of LCS: %d\n", lcs_length(X, Y, m, n));

    return 0;
}
Day 13: 模拟题训练
  • 知识点

    • 继续综合运用前面所学的知识点
    • 解决实际问题
  • 代码练习

    • 从PAT Basic历年真题中再挑选几个题目进行练习。
// 例题7:二叉树的层次遍历
#include <stdio.h>
#include <stdlib.h>

typedef struct TreeNode {
    int val;
    struct TreeNode *left;
    struct TreeNode *right;
} TreeNode;

TreeNode* create_node(int val) {
    TreeNode *node = (TreeNode *)malloc(sizeof(TreeNode));
    node->val = val;
    node->left = NULL;
    node->right = NULL;
    return node;
}

void level_order_traversal(TreeNode *root) {
    if (root == NULL) {
        return;
    }

    int front = 0, rear = 0;
    TreeNode *queue[1000];
    queue[rear++] = root;

    while (front < rear) {
        TreeNode *node = queue[front++];
        printf("%d ", node->val);

        if (node->left != NULL) {
            queue[rear++] = node->left;
        }
        if (node->right != NULL) {
            queue[rear++] = node->right;
        }
    }
}

int main() {
    TreeNode *root = create_node(1);
    root->left = create_node(2);
    root->right = create_node(3);
    root->left->left = create_node(4);
    root->left->right = create_node(5);
    root->right->left = create_node(6);
    root->right->right = create_node(7);

    level_order_traversal(root);

    return 0;
}

// 例题8:快速排序
#include <stdio.h>
#include <stdlib.h>

void quick_sort(int arr[], int low, int high) {
    if (low < high) {
        int pivot = arr[high];
        int i = low - 1;

        for (int j = low; j < high; ++j) {
            if (arr[j] < pivot) {
                ++i;
                int temp = arr[i];
                arr[i] = arr[j];
                arr[j] = temp;
            }
        }
        ++i;
        int temp = arr[i];
        arr[i] = arr[high];
        arr[high] = temp;

        quick_sort(arr, low, i - 1);
        quick_sort(arr, i + 1, high);
    }
}

int main() {
    int arr[] = {10, 7, 8, 9, 1, 5};
    int n = sizeof(arr) / sizeof(arr[0]);

    quick_sort(arr, 0, n - 1);

    printf("Sorted array: ");
    for (int i = 0; i < n; ++i) {
        printf("%d ", arr[i]);
    }
    printf("\n");

    return 0;
}
Day 14: 总结与模拟考试
  • 知识点

    • 复习前两周所学的知识点
    • 解决实际问题
  • 代码练习

    • 从PAT Basic历年真题中再挑选几个题目进行练习。
    • 模拟一次完整的PAT Basic考试,严格按照考试时间进行。
// 例题9:合并两个有序数组
#include <stdio.h>

void merge(int arr1[], int n1, int arr2[], int n2, int merged[]) {
    int i = 0, j = 0, k = 0;

    while (i < n1 && j < n2) {
        if (arr1[i] < arr2[j]) {
            merged[k++] = arr1[i++];
        } else {
            merged[k++] = arr2[j++];
        }
    }

    while (i < n1) {
        merged[k++] = arr1[i++];
    }

    while (j < n2) {
        merged[k++] = arr2[j++];
    }
}

int main() {
    int arr1[] = {1, 3, 5, 7};
    int n1 = sizeof(arr1) / sizeof(arr1[0]);

    int arr2[] = {2, 4, 6, 8};
    int n2 = sizeof(arr2) / sizeof(arr2[0]);

    int merged[100];
    merge(arr1, n1, arr2, n2, merged);

    printf("Merged array: ");
    for (int i = 0; i < n1 + n2; ++i) {
        printf("%d ", merged[i]);
    }
    printf("\n");

    return 0;
}

// 例题10:矩阵旋转
#include <stdio.h>

void rotate_matrix(int matrix[100][100], int n) {
    for (int layer = 0; layer < n / 2; ++layer) {
        int first = layer;
        int last = n - 1 - layer;
        for (int i = first; i < last; ++i) {
            int offset = i - first;
            int top = matrix[first][i];
            matrix[first][i] = matrix[last - offset][first];
            matrix[last - offset][first] = matrix[last][last - offset];
            matrix[last][last - offset] = matrix[i][last];
            matrix[i][last] = top;
        }
    }
}

int main() {
    int n;
    scanf("%d", &n);

    int matrix[100][100];
    for (int i = 0; i < n; ++i) {
        for (int j = 0; j < n; ++j) {
            scanf("%d", &matrix[i][j]);
        }
    }

    rotate_matrix(matrix, n);

    for (int i = 0; i < n; ++i) {
        for (int j = 0; j < n; ++j) {
            printf("%d ", matrix[i][j]);
        }
        printf("\n");
    }

    return 0;
}

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【IoPortDirect】- KRTS C++示例精讲(12)

IoPortDirect示例讲解 文章目录 IoPortDirect示例讲解结构说明代码说明 项目打开请查看【BaseFunction精讲】。 结构说明 IoPortDirect.cpp &#xff1a;源码 其余文件说明请查看【BaseFunction精讲】中的结构说明。 ps : 内核层中的数据、结构体需要一字节对齐&#xff0c;需…

Python——生成AIGC图像

文章目录 一、背景介绍 二、效果图展示 三、完整代码 四、分步解释 五、实用建议 1&#xff09;提示词技巧 2&#xff09;性能优化 3&#xff09;常见问题处理 4&#xff09;扩展功能建议 六、注意事项 1. 硬件要求 2. 法律合规 3. 模型安全 一、背景介绍 AIGC&a…

分巧克力(二分查找)

#include <iostream> using namespace std; int main() {// 请在此输入您的代码int n,k;cin>>n>>k;int N100005;int a[N],b[N];for(int i0;i<n;i){cin>>a[i]>>b[i];}int l1,r1e5;int ans;while(l<r){int midl(r-l)/2;long long cnt0;for(i…

嵌入式经常用到串口,如何判断串口数据接收完成?

说起通信&#xff0c;首先想到的肯定是串口&#xff0c;日常中232和485的使用比比皆是&#xff0c;数据的发送、接收是串口通信最基础的内容。这篇文章主要讨论串口接收数据的断帧操作。 空闲中断断帧 一些mcu&#xff08;如&#xff1a;stm32f103&#xff09;在出厂时就已经在…

大白话实战Gateway

网关功能 网关在分布式系统中起了什么作用?参考下图: 前端想要访问业务访问,就需要知道各个访问的地址,而业务集群服务有很多,前端需要记录非常多的服务器地址,这种情况下,我们需要对整个业务集群做一个整体屏蔽,这个时候就引入Gateway网关,它就是所有服务的请求入…

用大内存主机下载Visual Studio

用一台内存达到128G的主机下载Visual Studio 2022&#xff0c;用的是公司网络。下载速度让我吃了一惊&#xff0c;没人用网络了&#xff1f;还是网站提速了&#xff1f;以前最大只能达到5MB/秒。记录这段经历&#xff0c;是用来分析公司网络用的......

【C++语言】string 类

一、为什么要学习 string 类 C语言中&#xff0c;字符串是以 “\0” 结尾的一些字符的集合&#xff0c;为了操作方便&#xff0c;C标准库中提供了一些 str 系列的库函数&#xff0c;但是这些库函数与字符串是分离开的&#xff0c;不太符合 OOP 的思想&#xff0c;而且底层空间需…

深度学习-123-综述之AI人工智能与DL深度学习简史1956到2024

文章目录 1 AI与深度学习的简史1.1 人工智能的诞生(1956)1.2 早期人工神经网络(1940-1960年代)1.3 多层感知器MLP(1960年代)1.4 反向传播(1970-1980年代)1.5 第二次黑暗时代(1990-2000年代)1.6 深度学习的复兴(21世纪末至今)1.6.1 CNN卷积神经网络(1980-2010)1.6.2 RNN递归神经…

解决本地模拟IP的DHCP冲突问题

解决 DHCP 冲突导致的多 IP 绑定失效问题 前言 续接上一篇在本机上模拟IP地址。 在实际操作中&#xff0c;如果本机原有 IP&#xff08;如 192.168.2.7&#xff09;是通过 DHCP 自动获取的&#xff0c;直接添加新 IP&#xff08;如 10.0.11.11&#xff09;可能会导致 DHCP 服…

基于Llama 3.2-Vision的医学报告生成

记录运用大模型解决医学报告实例&#xff0c;仅介绍本地调用的情况。 前情提要 已安装 Python 显存不少于8G&#xff08;8G设备上测试成功&#xff0c;其他环境可以自行测试&#xff09;。 需要安装Ollama (Ollama 是一个允许在本地运行多模态模型的平台)。 方式1&#xff1…

DeepSeek预测25考研分数线

25考研分数马上要出了。 目前&#xff0c;多所大学已经陆续给出了分数查分时间&#xff0c;综合往年情况来看&#xff0c;每年的查分时间一般集中在2月底。 等待出成绩的日子&#xff0c;学子们的心情是万分焦急&#xff0c;小编用最近爆火的“活人感”十足的DeepSeek帮大家预…

DeepSeek赋能智慧文旅:新一代解决方案,重构文旅发展的底层逻辑

DeepSeek作为一款前沿的人工智能大模型&#xff0c;凭借其强大的多模态理解、知识推理和内容生成能力&#xff0c;正在重构文旅产业的发展逻辑&#xff0c;推动行业从传统的经验驱动向数据驱动、从人力密集型向智能协同型转变。 一、智能服务重构&#xff1a;打造全域感知的智…

【Python爬虫(26)】Python爬虫进阶:数据清洗与预处理的魔法秘籍

【Python爬虫】专栏简介&#xff1a;本专栏是 Python 爬虫领域的集大成之作&#xff0c;共 100 章节。从 Python 基础语法、爬虫入门知识讲起&#xff0c;深入探讨反爬虫、多线程、分布式等进阶技术。以大量实例为支撑&#xff0c;覆盖网页、图片、音频等各类数据爬取&#xff…

支持批量导出的软件,效率拉满!

今天给大家分享一款超实用的软件&#xff0c;它能帮你批量导出PPT里的图片&#xff0c;简直是提升工作效率的神器&#xff01; PPT转jpg PPT逐页导出为图片 这款软件超级简单易用&#xff0c;打开就能直接上手&#xff0c;不需要复杂的设置。 这个软件有三种功能&#xff0c; …

论文笔记(七十二)Reward Centering(二)

Reward Centering&#xff08;二&#xff09; 文章概括摘要2 简单的奖励中心 文章概括 引用&#xff1a; article{naik2024reward,title{Reward Centering},author{Naik, Abhishek and Wan, Yi and Tomar, Manan and Sutton, Richard S},journal{arXiv preprint arXiv:2405.0…

Jmeter连接数据库、逻辑控制器、定时器

Jmeter直连数据库 直接数据库的使用场景 直连数据库的关键配置 添加MYSQL驱动Jar包 方式一&#xff1a;在测试计划面板点击“浏览”按钮&#xff0c;将你的JDBC驱动添加进来 方式二&#xff1a;将MySQL驱动jar包放入到lib/ext目录下&#xff0c;重启JMeter 配置数据库连接信…

ORM框架详解:为什么不直接写SQL?

想象一下&#xff0c;你正在开发一个小型的在线书店应用。你需要存储书籍信息、用户数据和订单记录。作为一个初学者&#xff0c;你可能会想&#xff1a;“我已经学会了SQL&#xff0c;为什么还要使用ORM框架呢&#xff1f;直接写SQL语句不是更简单、更直接吗&#xff1f;” 如…

RT-Thread+STM32L475VET6实现红外遥控实验

文章目录 前言一、板载资源介绍二、具体步骤1. 确定红外接收头引脚编号2. 下载infrared软件包3. 配置infrared软件包4. 打开STM32CubeMX进行相关配置4.1 使用外部高速时钟&#xff0c;并修改时钟树4.2 打开定时器16(定时器根据自己需求调整)4.3 打开串口4.4 生成工程 5. 打开HW…

推荐一个github star45k+进阶的java项目及知识的网站

mall是github上star 45k的一个java项目 mall项目是一套电商系统&#xff0c;包括前台商城系统及后台管理系统&#xff0c;基于SpringBootMyBatis实现&#xff0c;采用Docker容器化部署。 前台商城系统包含首页门户、商品推荐、商品搜索、商品展示、购物车、订单流程、会员中心…

pyside6学习专栏(二):程序图像资源的加载方式

pyside6中的QLabel控件可以加载图像和gif动画&#xff0c;可以直接从外部文件加载&#xff0c;也可以从QRC类型的文件(实际是一脚本文件)经编绎生成对应的资源.PY模块文件(就是将qrc文本中指定的资源文件的16制内容写入.py文件)来使用&#xff0c;本文对两种方式作了一简单的示…