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 Sortint 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 Sortint 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 Sortint 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 Sortint 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;
}
相关文章:
14天速成PAT-BASIC基础知识!
两周关于PAT的基础学习计划。 Day 1: 基本语法和输入输出 知识点 数据类型(int, long, float, double, char)变量声明和初始化输入输出函数(scanf, printf)控制结构(if-else, switch, for, while, do-while࿰…...
Unity性能优化个人经验总结(不定期更新)
字符串 在使用常量或静态变量 Update、LateUpdate、FixedUpdate等每帧调用或调用频率很高的函数内使用字符串时,均使用常量或静态变量处理。 原因解释:除了常量或静态变量的字符串将会在每一次调用时,将会new一个新的字符串,导…...
vue3面试题进阶版
覆盖 Vue3 的核心知识点、高频考点及实战场景 一、基础与核心概念 MVVM 与 MVC 的区别 MVC:Model(数据)、View(视图)、Controller(控制器),视图更新需手动操作 DOM。MVVM࿱…...
python小项目编程-初级(5、词频统计,6、简单得闹钟)
1、词频统计 统计文本文件中每个单词出现的频率。 实现 import tkinter as tk from tkinter import filedialog, messagebox from collections import Counter import reclass WordFrequencyCounter:def __init__(self, master):self.master masterself.master.title("…...
掌握 ElasticSearch 四种match查询的原理与应用
文章目录 一、引言 (Introduction)二、准备工作:创建索引和添加示例数据三、match 查询四、match_all 查询五、multi_match 查询六、match_phrase 查询七、总结 (Conclusion) 一、引言 (Introduction) 在信息爆炸的时代,快速准确地找到所需信息至关重要…...
Vue 中组件通信的方式有哪些,如何实现父子组件和非父子组件之间的通信?
一、父子组件通信(垂直通信) 1. Props 传值(父 → 子) 实现方案: <!-- Parent.vue --> <template><Child :user"userData" /> </template><script setup> import { ref } …...
微信小程序(uni)+蓝牙连接+Xprint打印机实现打印功能
1.蓝牙列表实现,蓝牙设备展示,蓝牙连接 <template><view class"container"><view class"container_top"><view class"l">设备名称</view><view class"r">{{state.phoneNam…...
QT 建立一片区域某种颜色
绘制一个位于(50, 50)的200x200的红色矩形 #include "widget.h" #include "ui_widget.h" #include <QPainter>Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget) {ui->setupUi(this);update(); }Widget::~Widget() {delete…...
Go Web 项目实战:构建 RESTful API、命令行工具及应用部署
Go Web 项目实战:构建 RESTful API、命令行工具及应用部署 Go 语言因其简洁高效、并发支持强大等特点,已经成为了后端开发的热门选择之一。本篇文章将通过实战案例带领你学习如何使用 Go 构建一个简单的 RESTful API,开发命令行工具…...
Eclipse自动排版快捷键“按了没有用”的解决办法
快捷键按了没有用,通常是因为该快捷键方式被其他软件占用了,即别的软件也设置了这个快捷键,导致你按了之后电脑不知道该响应哪个软件。 解决办法:1.将当前软件的这个快捷键改了;2.找到占用的那个软件,把那…...
springboot404-基于Java的校园礼服租赁系统(源码+数据库+纯前后端分离+部署讲解等)
💕💕作者: 爱笑学姐 💕💕个人简介:十年Java,Python美女程序员一枚,精通计算机专业前后端各类框架。 💕💕各类成品Java毕设 。javaweb,ssm…...
PHP支付宝--转账到支付宝账户
官方参考文档: https://opendocs.alipay.com/open/62987723_alipay.fund.trans.uni.transfer?sceneca56bca529e64125a2786703c6192d41&pathHash66064890 可以使用默认应用,也可以自建新应用,此处以默认应用来讲解【默认应用默认支持…...
推荐一款AI大模型托管平台-OpenWebUI
推荐一款AI大模型托管平台-OpenWebUI 1. OpenWebUI 1. OpenWebUI什么? 官网地址:https://openwebui.com/ GitHub地址: https://github.com/open-webui/open-webui Open WebUI 是一个可扩展、功能丰富且用户友好的自托管 AI 平台,旨在完全离…...
PHP Composer:高效项目依赖管理工具详解
PHP Composer:高效项目依赖管理工具详解 引言 随着Web开发领域的不断扩展,项目的复杂性也在逐渐增加。为了提高开发效率,减少重复劳动,依赖管理工具应运而生。其中,PHP的Composer成为了开发者们的首选。本文将详细介绍PHP Composer的功能、使用方法以及在实际开发中的应…...
代码随想录D50-51 图论 Python
理论基础 理论基础部分依然沿用代码随想录教程中的介绍: 图的种类 度 连通性 连通性用于表示图中节点的连通情况。 如果有节点不能到达其他节点,则为非连通图,想象将多个水分子表示为图,不考虑非键作用,这张图就不是…...
【八股】计算机网络
HTTP 应用层网络层传输层接口层数据链路层 HTTP基本概念 HTTP是什么? HTTP是超文本传输协议 HTTP 常见的状态码有哪些? 200、204、206 成功 301、302、304 重定向 400、403、404 客户端错误 500、501、502、503 服务端错误...
在 Spring Boot 中使用 `@Autowired` 和 `@Bean` 注解
文章目录 在 Spring Boot 中使用 Autowired 和 Bean 注解示例背景 1. 定义 Student 类2. 配置类:初始化 Bean3. 测试类:使用 Autowired 注解自动注入 Bean4. Spring Boot 的自动装配5. 总结 在 Spring Boot 中使用 Autowired 和 Bean 注解 在 Spring Bo…...
Qt 保留小数点 固定长度 QString 格式化
QString的arg()函数格式化输出double类型数值,包括fieldWidth、fmt、prec和fillChar参数的作用。示例代码展示了如何设置精度和填充字符,以及字段宽度的影响。文中提到,当fieldWidth小于实际长度时,前面的填充不会被截断。此外&am…...
Mac M3/M4 本地部署Deepseek并集成vscode
Mac 部署 使用傻瓜集成平台ollama,ollama平台依赖于docker,Mac的M3/M4 因doesn’t have VT-X/AMD-v enabled 所以VB,VM无法使用,导致docker无法启动,需要使用docker的替代品podman, 它完全兼容docker brew install p…...
TikTok账户安全指南:如何取消两步验证?
TikTok账户安全指南:如何取消两步验证? 在这个数字化的时代,保护我们的在线账户安全变得尤为重要。TikTok,作为全球流行的社交媒体平台,其账户安全更是不容忽视。两步验证作为一种增强账户安全性的措施,虽…...
【C++复习专题】—— 类和对象,包含类的引入、访问限定符、类的6个默认成员函数等
1.类的定义 class classname {//类体:由成员函数和成员变量组成 }; class为定义类的关键字,classname为类的名字,{}中为类的主体。 类体中的内容称为类的成员:类中的变量称为类的属性或成员变量;类中的函数称为类的方…...
Spring--BeanDefinition的用法
原文网址:Spring--BeanDefinition的用法_IT利刃出鞘的博客-CSDN博客 简介 本文介绍BeanDefinition的用法。 BeanDefinition是Bean的信息,用于生成Bean。 示例:手动注册Bean 待填充 BeanDefinition的作用 get 下图是通过beanDefinitio…...
关于C#的一些基础知识点汇总
1.C#结构体可以继承接口吗?会不会产生GC? 在 C# 中,结构体不能继承类,但可以实现接口。 代码: interface IMyInterface {void MyMethod(); }struct MyStruct : IMyInterface {public void MyMethod(){Console.Write…...
一文讲解Redis为什么读写性能高以及I/O复用相关知识点
Redis为什么读写性能高呢? Redis 的速度⾮常快,单机的 Redis 就可以⽀撑每秒十几万的并发,性能是 MySQL 的⼏⼗倍。原因主要有⼏点: ①、基于内存的数据存储,Redis 将数据存储在内存当中,使得数据的读写操…...
Hadoop-HA(高可用)机制
首先:在每个NAMENODE上都会有一个zkfc(zookeeper failover colltroller) ,负责这两个的状态管理。哪个是(active和standby)然后写入zk集群里面。同时监控自己所在的机器是否正常。一旦active上zkfc的发现异…...
51单片机-按键
1、独立按键 1.1、按键介绍 轻触开关是一种电子开关,使用时,轻轻按开关按钮就可使开关接通,当松开手时,开关断开。 1.2、独立按键原理 按键在闭合和断开时,触点会存在抖动现象。P2\P3\P1都是准双向IO口,…...
深度学习的力量:精准肿瘤检测从此不再遥远
目录 引言 一、医学图像分析的挑战与深度学习的优势 1.1 医学图像分析的挑战 1.2 深度学习的优势 二、肿瘤检测的深度学习模型设计 2.1 卷积神经网络(CNN)的基本原理 2.2 网络架构设计 2.3 模型训练 三、肿瘤检测中的挑战与解决方案 3.1 数据不…...
初尝git自结命令大全与需要理解的地方记录
常用命令 git init–初始化工作区touch 文件全称–在工作区创建文档rm 文件全称 --删除文档notepad 文件全称–在工作区打开文档cat 文件全称–在显示框显示文档的东西git status --显示工作区的文件冲突的文件 (git add 文件全称或者.) —将工作区文件…...
LangChain 技术入门指南:探索语言模型的无限可能
在当今的技术领域,LangChain 正逐渐崭露头角,成为开发语言模型应用的强大工具。如果你渴望深入了解并掌握这一技术,那么就跟随本文一起开启 LangChain 的入门之旅吧! (后续将持续输出关于LangChain的技术文章,有兴趣的同学可以关注…...
Nginx WebSocket 长连接及数据容量配置
WebSocket 协议是实现实时通信的关键技术。相比于传统的 HTTP 请求-响应模式,WebSocket 提供了双向、持久化的通信方式。Nginx 作为一个高性能的反向代理服务器,可以非常有效地处理 WebSocket 连接,但要正确处理 WebSocket 长连接和传输大数据…...
