AtCoder Beginner Contest 362

news2024/11/14 19:59:36

🚀欢迎来到本文🚀
🍉个人简介:陈童学哦,彩笔ACMer一枚。
🏀所属专栏:Codeforces
本文用于记录回顾总结本彩笔的解题思路便于加深理解。

比赛题目地址:AtCoder Beginner Contest 362

📢📢📢传送门

  • A - Buy a Pen
    • 解题思路
    • AC代码
  • B - Right Triangle
    • 解题思路
    • AC代码
  • C - Sum = 0
    • 解题思路
    • AC代码
  • D - Shortest Path 3
    • 解题思路
    • AC代码
  • E - Count Arithmetic Subsequences
    • 解题思路
    • AC代码
  • F - Perfect Matching on a Tree
    • 解题思路
    • AC代码
  • G - Count Substring Query
    • 解题思路
    • AC代码

A - Buy a Pen

Problem Statement

Takahashi came to a store to buy a pen. Here, a red pen costs R R R yen, a green pen costs G G G yen, and a blue pen costs B B B yen.

Takahashi dislikes the color C C C. If C C C is Red, he cannot buy a red pen; if C C C is Green, he cannot buy a green pen; and if C C C is Blue, he cannot buy a blue pen.

Determine the minimum amount of money he needs to buy one pen.

在这里插入图片描述

解题思路

模拟即可。输出另外两只笔的最小值即可。

AC代码

#include<bits/stdc++.h>
#define look(x) cout << #x << " ==  " << x << "\n"
using namespace std;
using i64 = long long;
const int N = 2e3 + 10;
const int MOD1 = 1e9 + 7;
const int MOD2 = 998244353;
void solve(){
	int a,b,c;
	cin >> a >> b >> c;
	string s;
	cin >> s;
	if(s[0] == 'R'){
		cout << min(b,c);
	}else if(s[0] == 'G'){
		cout << min(a,c);
	}else{
		cout << min(a,b);
	}
}

int main(){	

	ios::sync_with_stdio(false);
	cin.tie(nullptr);

	int t = 1;
//	cin >> t;

	while(t --){
		solve();
	}
	
	return 0;

B - Right Triangle

Problem Statement

In the x y xy xy-plane, there are three points A ( x A , y A ) A(x_A, y_A) A(xA,yA), B ( x B , y B ) B(x_B, y_B) B(xB,yB), and C ( x C , y C ) C(x_C, y_C) C(xC,yC) that are not collinear. Determine whether the triangle A B C ABC ABC is a right triangle.

在这里插入图片描述

解题思路

判断是否存在任意两边平方和等于第三条边的平方和即可(直角三角形的判定条件)或判断向量叉积。

AC代码

#include<bits/stdc++.h>
#define look(x) cout << #x << " ==  " << x << "\n"
using namespace std;
using i64 = long long;
const int N = 2e3 + 10;
const int MOD1 = 1e9 + 7;
const int MOD2 = 998244353;
void solve(){
	int a1,b1,a2,b2,a3,b3;
	cin >> a1 >> b1;
	cin >> a2 >> b2;
	cin >> a3 >> b3;
	string ans;
	if(pow(a1 - a2,2) + pow(b1 - b2,2) + pow(a1 - a3,2) + pow(b1 - b3,2) == pow(a2 - a3,2) + pow(b2 - b3,2)){
		ans = "Yes";
	}else if(pow(a3 - a2,2) + pow(b3 - b2,2) + pow(a1 - a3,2) + pow(b1 - b3,2) == pow(a2 - a1,2) + pow(b2 - b1,2)){
		ans = "Yes"; 
	}else if(pow(a1 - a2,2) + pow(b1 - b2,2) + pow(a2 - a3,2) + pow(b2 - b3,2) == pow(a1 - a3,2) + pow(b1 - b3,2)){
		ans = "Yes";
	}else{
		ans = "No";
	}
	cout << ans << "\n";
}

int main(){	

	ios::sync_with_stdio(false);
	cin.tie(nullptr);

	int t = 1;
//	cin >> t;

	while(t --){
		solve();
	}
	
	return 0;
}

C - Sum = 0

Problem Statement

You are given N N N pairs of integers ( L 1 , R 1 ) , ( L 2 , R 2 ) , … , ( L N , R N ) (L_1, R_1), (L_2, R_2), \ldots, (L_N, R_N) (L1,R1),(L2,R2),,(LN,RN).

Determine whether there exists a sequence of N N N integers X = ( X 1 , X 2 , … , X N ) X = (X_1, X_2, \ldots, X_N) X=(X1,X2,,XN) that satisfies the following conditions, and print one such sequence if it exists.

  • L i ≤ X i ≤ R i L_i \leq X_i \leq R_i LiXiRi for each i = 1 , 2 , … , N i = 1, 2, \ldots, N i=1,2,,N.
  • ∑ i = 1 N X i = 0 \displaystyle \sum_{i=1}^N X_i = 0 i=1NXi=0.

在这里插入图片描述

解题思路

首先我们先考虑什么情况下不存在这样的一个序列呢?
求所有区间的左边界值的总和 s u m 1 sum1 sum1,如果 s u m 1 > 0 sum1 > 0 sum1>0的话必然不存在这样的一个序列。
因为在每个区间都取最小值的情况下都只大于0的情况下无论怎么样取每个区间的值都只会大于等于 s u m 1 sum1 sum1
否则 s u m 1 < = 0 sum1 <= 0 sum1<=0的情况下肯定存在一个序列的总和为0。
然后我们就可以依次遍历每个区间让在这个区间的所取得那个数去动态变化保证总和为0。
我们开始可以设置一个 a n s ans ans数组依次取值区间得左边界 l [ i ] l[i] l[i],然后每次加 a n s [ i ] ans[i] ans[i]加上一个 m i n ( − s u m 1 , r [ i ] − l [ i ] ) min(-sum1,r[i] - l[i]) min(sum1,r[i]l[i])即可。

AC代码

#include<bits/stdc++.h>
#define look(x) cout << #x << " ==  " << x << "\n"
using namespace std;
using i64 = long long;
const int N = 2e5 + 10;
const int MOD1 = 1e9 + 7;
const int MOD2 = 998244353;
i64 l[N],r[N];
i64 ans[N];
i64 sum1 = 0,sum2 = 0;
void solve(){
	int n;
	cin >> n;
	for(int i = 1;i <= n;i ++){
		cin >> l[i] >> r[i];
		sum1 += l[i];
		sum2 += r[i];
		ans[i] = l[i];  //ans数组记录每个区间所取得数值
	}
	if(sum1 > 0 || sum2 < 0){
		cout << "No\n";
		return;
	}else{
		cout << "Yes\n";
		for(int i = 1;i <= n;i ++){
			//加上使得sum1靠近0得值(不能大于区间的差值也不需要大于sum1的绝对值)
			int t = min(-sum1,r[i] - l[i]);
			sum1 += t;
			ans[i] += t;
			if(sum1 == 0){
				break;
			}
		}
	}
	for(int i = 1;i <= n;i ++){
		cout << ans[i] << " ";
	}
}

int main(){	

	ios::sync_with_stdio(false);
	cin.tie(nullptr);

	int t = 1;
//	cin >> t;

	while(t --){
		solve();
	}
	
	return 0;
}

D - Shortest Path 3

Problem Statement

You are given a simple connected undirected graph with N N N vertices and M M M edges. Each vertex i   ( 1 ≤ i ≤ N ) i\,(1\leq i \leq N) i(1iN) has a weight A i A_i Ai. Each edge j   ( 1 ≤ j ≤ M ) j\,(1\leq j \leq M) j(1jM) connects vertices U j U_j Uj and V j V_j Vj bidirectionally and has a weight B j B_j Bj.

The weight of a path in this graph is defined as the sum of the weights of the vertices and edges that appear on the path.

For each i = 2 , 3 , … , N i=2,3,\dots,N i=2,3,,N, solve the following problem:

  • Find the minimum weight of a path from vertex 1 1 1 to vertex i i i.

在这里插入图片描述

解题思路

跑个 D i j k s t r a Dijkstra Dijkstra的堆优化即可,复杂度为 O ( n l o g n ) O(n logn) O(nlogn)

AC代码

#include<bits/stdc++.h>
#define look(x) cout << #x << " ==  " << x << "\n"
using namespace std;
using i64 = long long;
const int N = 2e5 + 10;
const int MOD1 = 1e9 + 7;
const int MOD2 = 998244353;
//存图,pair存与之相连的点和两点之间边的权值
vector<pair<int,int>> g[N];
//每个点的权值
int a[N];
//起点1到其他点的最小权值
i64 dis[N];
//判断该点是否跑过
bool st[N];
void solve(){
	int n,m;
	cin >> n >> m;
	for(int i = 1;i <= n;i ++){
		cin >> a[i];
	}
	for(int i = 1;i <= m;i ++){
		int u,v,w;
		cin >> u >> v >> w;
		g[u].push_back({v,w});
		g[v].push_back({u,w});
	}
	dis[1] = a[1];
	//优先队列,按权值小的优先来排序
	priority_queue<pair<i64,i64>,vector<pair<i64,i64>>,greater<pair<i64,i64>>> q;
	q.push({a[1],1});
	for(int i = 2;i <= n;i ++){
		dis[i] = 1e18;
	}
	//跑Dijkstra
	while(!q.empty()){
		auto [x,y] = q.top();
		q.pop();
		if(st[y]){
			continue;
		}
		st[y] = true;
		for(auto [k1,k2] : g[y]){
			//如果权值更小就更新
			if(dis[k1] > x + k2 + a[k1]){
				dis[k1] = x + k2 + a[k1];
				q.push({dis[k1],k1});
			}
		}
	}
	//输出每个点距离起点的最小权值
	for(int i = 2;i <= n;i ++){
		cout << dis[i] << " ";
	}		
}

int main(){	

	ios::sync_with_stdio(false);
	cin.tie(nullptr);

	int t = 1;
//	cin >> t;

	while(t --){
		solve();
	}
	
	return 0;
}

E - Count Arithmetic Subsequences

Problem Statement

You are given a sequence A = ( A 1 , A 2 , … , A N ) A = (A_1, A_2, \dots, A_N) A=(A1,A2,,AN) of length N N N. For each k = 1 , 2 , … , N k = 1, 2, \dots, N k=1,2,,N, find the number, modulo 998244353 998244353 998244353, of (not necessarily contiguous) subsequences of A A A of length k k k that are arithmetic sequences. Two subsequences are distinguished if they are taken from different positions, even if they are equal as sequences.

What is a subsequence? A subsequence of a sequence A A A is a sequence obtained by deleting zero or more elements from A A A and arranging the remaining elements without changing the order.

在这里插入图片描述

解题思路

要求所有长度为 1 到 N 1 到 N 1N的等差数列各有多少个。
首先我们可以发现N很小,所以其实我们考虑枚举所有的公差,然后考虑dp推出状态转移方程。
首先考虑第一个维度为 i i i代表第i个数,第二个维度 j j j代表第j个数,但是由于直接枚举出来的公差可能会重复且数值很大,所以我们需要排序去重然后二分求出公差的位置 x x x 代表这个公差。
所以第二个维度应该为 x x x,最后还需要一个维度 k k k来表示这个序列的长度。
最后的dp数组就可表示为这样 d p [ i ] [ k ] [ x ] dp[i][k][x] dp[i][k][x]

AC代码

#include<bits/stdc++.h>
#define look(x) cout << #x << " ==  " << x << "\n"
using namespace std;
using i64 = long long;
const int N = 2e5 + 10;
const int MOD1 = 1e9 + 7;
const int MOD2 = 998244353;
int a[100];
//dp数组
i64 dp[81][81][81 * 81];
i64 ans[100];
void solve(){
	int n;
	cin >> n;
	for(int i = 1;i <= n;i ++){
		cin >> a[i];
	}
	vector<int> f;
	//枚举所有的公差
	for(int i = 1;i <= n;i ++){
		for(int j = 1;j < i;j ++){
			f.push_back(a[i] - a[j]);
		}
	}
	//排序去重
	sort(f.begin(),f.end());
	f.erase(unique(f.begin(),f.end()),f.end());
	//i代表第i个数现在进行到
	for(int i = 1;i <= n;i ++){
		//j代表在i个数的情况下往前枚举公差
		for(int j = 1;j < i;j ++){
			//k代表序列长度
			for(int k = 1;k <= j;k ++){
				//二分在f中找出a[i]-a[j]公差的位置
				int x = lower_bound(f.begin(),f.end(),a[i] - a[j]) - f.begin() + 1;
				//长度为1就直接加1
				if(k + 1 == 2){
					dp[i][k + 1][x] ++;
				}else{
				//否则就加上没算第i个数是的dp,公差都是x,只不过没算第i个数时长度就是
				//算了第i个数时的k+1减去1也就是k了。
					dp[i][k + 1][x] += dp[j][k][x];
				}
				dp[i][k + 1][x] %= MOD2;
			}
		}
	}
	//将所有公差下长度为k的序列答案累加。
	for(int i = 1;i <= n;i ++){
		for(int j = 1;j <= f.size();j ++){
			for(int k = 1;k <= n;k ++){
				ans[k] += dp[i][k][j];
				ans[k] %= MOD2;
			}
		}
	}
	//长度为1的序列就是所有完整序列的大小
	cout << n << " ";
	for(int i = 2;i <= n;i ++){
		cout << ans[i] << " ";
	}
	
}
int main(){	

	ios::sync_with_stdio(false);
	cin.tie(nullptr);

	int t = 1;
//	cin >> t;

	while(t --){
		solve();
	}
	
	return 0;
}

F - Perfect Matching on a Tree

Problem Statement

You are given a tree T T T with N N N vertices. The vertices are numbered 1 1 1 to N N N, and the i i i-th edge ( 1 ≤ i ≤ N − 1 ) (1 \leq i \leq N-1) (1iN1) connects vertices u i u_i ui and v i v_i vi bidirectionally.

Using T T T, define a complete graph G G G with N N N vertices as follows:

  • The weight w ( x , y ) w(x,y) w(x,y) of the edge between vertices x x x and y y y in G G G is the shortest distance between vertices x x x and y y y in T T T.

Find one maximum weight maximum matching in G G G. That is, find a set of ⌊ N / 2 ⌋ \lfloor N/2 \rfloor N/2 pairs of vertices M = { ( x 1 , y 1 ) , ( x 2 , y 2 ) , … , ( x ⌊ N / 2 ⌋ , y ⌊ N / 2 ⌋ ) } M=\{(x_1,y_1),(x_2,y_2),\dots,(x_{\lfloor N/2 \rfloor},y_{\lfloor N/2 \rfloor})\} M={(x1,y1),(x2,y2),,(xN/2,yN/2)} such that each vertex 1 , 2 , … , N 1,2,\dots, N 1,2,,N appears in M M M at most once, and ∑ i = 1 ⌊ N / 2 ⌋ w ( x i , y i ) \displaystyle \sum_{i=1}^{\lfloor N/2 \rfloor} w(x_i,y_i) i=1N/2w(xi,yi) is maximized.

解题思路

待补 待补 待补

AC代码

G - Count Substring Query

Problem Statement

You are given a string S S S consisting of lowercase English letters.

You are also given Q Q Q queries to process sequentially. The i i i-th query is described as follows:

  • A string T i T_i Ti consisting of lowercase English letters is given. Print the number of substrings of S S S that equal T i T_i Ti. Two substrings are distinguished if they are taken from different positions, even if they are equal as strings.

在这里插入图片描述

解题思路

要找每个子串出现的次数,AC自动机。

AC代码

#include<bits/stdc++.h>
#define look(x) cout << #x << " ==  " << x << "\n"
using namespace std;
using i64 = long long;
const int N = 1e6 + 10;
const int MOD1 = 1e9 + 7;
const int MOD2 = 998244353;
int tire[N][26],cnt[N],idx;
int ne[N],q[N],f[N],id[N];
string s;
void insert1(string s){
	int p = 0;
	for(int i = 0;s[i];i ++){
		int u = s[i] - 'a';
		if(!tire[p][u]){
			tire[p][u] = ++ idx;
		}
		p = tire[p][u];
		f[p] ++;
	}
}
void insert2(int x){
	int p = 0;
	for(int i = 0;s[i];i ++){
		int u = s[i] - 'a';
		if(!tire[p][u]){
			tire[p][u] = ++ idx;
		}
		p = tire[p][u];
	}
	id[x] = p;
}
void build(){
	int hh = 0,tt = -1;
	for(int i = 0;i < 26;i ++){
		if(tire[0][i]){
			q[++ tt] = tire[0][i];
		}
	}
	while(hh <= tt){
		int k = q[hh ++];
		for(int i = 0;i < 26;i ++){
			int p = tire[k][i];
			if(!p){
				tire[k][i] = tire[ne[k]][i];
			}else{
				ne[p] = tire[ne[k]][i];
				q[++ tt] = p;
			}
		}
	}
}
void solve(){
	cin >> s;
	insert1(s);
	int n;
	cin >> n;
	for(int i = 1;i <= n;i ++){
		cin >> s;
		insert2(i);
	}
	build();
	for(int i = idx - 1;i >=0;i --){
		f[ne[q[i]]] += f[q[i]];
	}
	for(int i = 1;i <= n;i ++){
		cout << f[id[i]] << "\n";
	}
}


int main(){	

	ios::sync_with_stdio(false);
	cin.tie(nullptr);

	int t = 1;
//	cin >> t;

	while(t --){
		solve();
	}
	
	return 0;
}

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

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

相关文章

【保卫花果山】游戏

游戏介绍 拯救花果山是一款玩家能够进行趣味闯关的休闲类游戏。拯救花果山中玩家需要保护花果山的猴子&#xff0c;利用各种道具来防御妖魔鬼怪的入侵&#xff0c;游戏中玩家需要面对的场景非常的多样&#xff0c;要找到各种应对敌人的方法。拯救花果山里玩家可以不断的进行闯…

vue基于Cookies实现记住密码自动登录功能

vue基于Cookies实现记住密码自动登录功能 Cookies 和localStorage存储比对 实现记住密码功能时&#xff0c;使用 Cookies 和使用 localStorage 各有其优势和考虑因素&#xff0c;具体需要取决于需求和安全考量&#xff1a; 1、Cookies 的优势&#xff1a; 广泛支持&#x…

中介者模式详解:概念、优点及实例

目录 中介者模式中介者模式结构中介者模式适用场景中介者模式优缺点练手题目题目描述输入描述输出描述题解 中介者模式 中介者模式是一种行为设计模式&#xff0c; 能让你减少对象之间混乱无序的依赖关系。 该模式会限制对象之间的直接交互&#xff0c; 迫使它们通过一个中介者…

windows ssh的登录,私钥权限太开放 WARNING: UNPROTECTED PRIVATE KEY FILE!

问题描述 ssh -i wang -D localhost:1080 wangsg.ks99.topBad permissions. Try removing permissions for user Permissions for xxx are too open. F:\pms\pms-gpg-key\ssh-key\wang>ssh -i wang -D localhost:1080 wangsg.ks99.top Bad permissions. Try removing perm…

查看公网IP的网络出口

文章目录 背景 背景 有时候在各种交易或其他时候&#xff0c;会被问到给我一个公网IP&#xff0c;我来帮你加白名单。 这个怎么怎么获取公网IP呢&#xff0c;在自己本机查看ipconfig或者ifconfig ip a 等命令查到的一般都是局域网的IP&#xff0c;每台机器都需要一个IP来进行对…

【文档智能 RAG】RAG新基建-RAG性能增强关键技术点及通用文档解析工具-TextIn

前言 在私有领域知识问答和企业知识管理领域&#xff0c;结合检索增强型生成模型&#xff08;Retrieval-Augmented Generation, RAG&#xff09;大模型&#xff08;Large Language Model, LLM&#xff09;已成为一种趋势。然而&#xff0c;在RAG系统的文档预处理阶段和检索阶段…

【Elasticsearch7】3-基本操作

目录 RESTful 数据格式 HTTP操作 索引操作 倒排索引 创建索引 查看所有索引 查看单个索引 删除索引 文档操作 创建文档 查看文档 ​编辑 全量修改 ​编辑局部修改 删除文档 条件删除文档 高级查询 条件查询 URL带参查询 请求体带参查询 带请求体方式的查…

STM32的ADC详解

目录 一、ADC简介 二、ADC的时钟 三、ADC特性 四、ADC功能说明 五、规则通道和注入通道 1.规则通道 2.注入通道 3.区别 六、数据寄存器 1.右对齐 2.左对齐 七、转换模式 1.单次转换模式 2.续转换模式 3.扫描模式 4.区别 八、程序实现 1.需求 2.ADC初始化 3.A…

InfiniBand网络-赋能高性能计算的卓越引擎

InfiniBand&#xff1a;赋能高性能计算网络的卓越引擎 InfiniBand作为一种先进的内网计算平台&#xff0c;已成为驱动高性能计算&#xff08;HPC&#xff09;、人工智能&#xff08;AI&#xff09;以及超大规模云基础设施演进的核心力量&#xff0c;其展现出无可比拟的性能优势…

mongodb数据导出与导入

一、先去检查mongodump mongodump --version 如果报 mongodump version: built-without-version-string 或者其他的较老的版本&#xff0c;直接去下载最新的【传送门】 【以Ubuntu18.04为例】 安装工具 假设你下载的是 .tgz 文件&#xff08;适用于 Linux 系统&#xff09;&am…

Java中SPI机制原理解析

使用SPI机制前后的代码变化 加载MySQL对JDBC的Driver接口实现 在未使用SPI机制之前&#xff0c;使用JDBC操作数据库的时候&#xff0c;一般会写如下的代码&#xff1a;// 通过这行代码手动加载MySql对Driver接口的实现类 Class.forName("com.mysql.jdbc.Driver") Dr…

鸿蒙开发error: failed to start ability

鸿蒙开发项目编译过后不能启动 项目在模拟器运行报&#xff1a; error: failed to start ability. Error while Launching ability 解决办法&#xff1a; 1&#xff0c;看了一些文章说是把module.json5配置文件中的"exported"由false改成true&#xff0c;没有解…

Python 实现股票指标计算——BIAS

BIAS (Bias Ratio) - 乖离率 1 公式 BIAS (当日收盘价 - N日平均收盘价) ➗ N日平均收盘价 ✖ 100&#xff05; N一般取6、12、24 2 数据准备 我们以科创50指数 000688 为例&#xff0c;指数开始日期为2019-12-31&#xff0c;数据格式如下&#xff1a; 3 计算过程 def c…

Java 中的异常

异常&#xff1a;就是出现的问题。 在Java中异常被当成对象进行处理&#xff0c;所有的异常类都继承于Throwable类&#xff0c;如果Java提供的异常类并不能满足需求&#xff0c;用户还可以自己定义一个异常类。 下面是异常体系结构&#xff1a; Throwable又分成了Error和Exce…

《无所不能的JavaScript · 对象简介》

&#x1f4e2; 大家好&#xff0c;我是 【战神刘玉栋】&#xff0c;有10多年的研发经验&#xff0c;致力于前后端技术栈的知识沉淀和传播。 &#x1f497; &#x1f33b; CSDN入驻不久&#xff0c;希望大家多多支持&#xff0c;后续会继续提升文章质量&#xff0c;绝不滥竽充数…

OpenStack Yoga版安装笔记(七)glance练习补充

1、练习场景说明 在OpenStack Yoga版安装笔记&#xff08;五&#xff09;中&#xff0c;glance已经在controller node虚拟机上安装完成&#xff0c;并且已经成功拍摄了快照。 此时&#xff0c;controller node虚机已经安装了keystone、keystone DB、glance、glance DB、OpenSta…

利用【MATLAB】和【Python】进行【图与网络模型】的高级应用与分析】

目录 一、图与网络的基本概念 1. 无向图与有向图 2. 简单图、完全图、赋权图 3. 顶点的度 4. 子图与连通性 5. 图的矩阵表示 MATLAB代码实例 Python代码实例 二、最短路径问题 1. 最短路径问题的定义 2. Dijkstra算法 MATLAB代码实例 Python代码实例 三、最小生…

昇思MindSpore学习总结十七 —— 基于MindSpore通过GPT实现情感分类

1、要求 2、导入了一些必要的库和模块 以便在使用MindSpore和MindNLP进行深度学习任务时能使用各种功能&#xff0c;比如数据集处理、模型训练、评估和回调功能。 import os # 导入操作系统相关功能的模块&#xff0c;如文件和目录操作import mindspore # 导入MindSpore库&a…

入门C语言只需一个星期(星期六)

点击上方"蓝字"关注我们 01、创建结构体 struct MyStructure { // 结构声明 int myNum; // 成员&#xff08;int 变量&#xff09; char myLetter; // 成员&#xff08;char 变量&#xff09;}; // 用分号结束结构创建一个名为 s1 的结构变量​struct myStru…

# Redis 入门到精通(九)-- 主从复制(1)

Redis 入门到精通&#xff08;九&#xff09;-- 主从复制&#xff08;1&#xff09; 一、redis 主从复制 – 主从复制简介 1、互联网“三高”架构 高并发高性能高可用 2、你的“Redis”是否高可用&#xff1f; 1&#xff09;单机 redis 的风险与问题 问题1.机器故障  现…