AtCoder Beginner Contest 404 A-E 题解
还是ABC好打~比ARC好打多了(
题解部分
A - Not Found
给定你一个长度最大25的字符串,任意输出一个未出现过的小写字母
签到题,map或者数组下标查询一下就好
#include<bits/stdc++.h>using namespace std;#define int long long
#define lowbit(x) x&(-x)const int MOD=1e9+7;
const int N=1000100;int a[N];void solve() {init();string s;cin>>s;map<char,int>mp;int len = s.length();for(int i=0;i<len;i++) {mp[s[i]]=1;}for(int i=0;i<26;i++) {if(!mp[(char)('a'+i)]) {cout<<(char)('a'+i);return ;}}
}signed main() {//ios::sync_with_stdio(false);//cin.tie(0);//cout.tie(0);//cout<<prime[cnt-1]<<"\n";//for(int i=1;i<=cnt;i++) cout<<prime[i]<<"\n";int t=1;//cin>>t;while(t--) {solve();}return 0;
}
B - Grid Rotation
给定两个二维字符数组,你能进行两种操作:将第一个字符数组顺时针旋转90度或者将第一个字符数组任意位置改为任意字符,问你最少需要多少次操作能将第一个字符数组变成第二个字符数组
纯模拟题,单独封装一个函数用于数组的旋转即可(不会有人真的手动写完旋转后的数组吧)
代码如下:
#include<bits/stdc++.h>using namespace std;#define int long long
#define lowbit(x) x&(-x)const int MOD=1e9+7;
const int N=1000100;int a[N];char b[110][110];
char c[110][110];
char t[110][110];int n;int minvalue = MOD;void rev() {for(int i=1;i<=n;i++) {for(int j=1;j<=n;j++) {c[i][j] = b[n-j+1][i];}}for(int i=1;i<=n;i++) {for(int j=1;j<=n;j++)b[i][j] = c[i][j];}
}void solve() {init();cin>>n;for(int i=1;i<=n;i++) {for(int j=1;j<=n;j++) cin>>b[i][j];}for(int i=1;i<=n;i++) {for(int j=1;j<=n;j++) cin>>t[i][j];}for(int i=1;i<=4;i++) {int sum=0;for(int j=1;j<=n;j++) {for(int k=1;k<=n;k++) {if(b[j][k] != t[j][k]) sum++;}}//cout<<sum<<"\n";minvalue = min(minvalue,sum + i - 1);rev();}cout<<minvalue<<"\n";
}signed main() {//ios::sync_with_stdio(false);//cin.tie(0);//cout.tie(0);//cout<<prime[cnt-1]<<"\n";//for(int i=1;i<=cnt;i++) cout<<prime[i]<<"\n";int t=1;//cin>>t;while(t--) {solve();}return 0;
}
C - Cycle Graph?
给定你n个节点m条边,问你这个图是否有且仅有一条连接所有节点的欧拉回路
很简单,只要满足有n条边,每个点都是联通的并且每个点都有两条边就行
代码如下:
#include<bits/stdc++.h>using namespace std;#define int long long
#define lowbit(x) x&(-x)const int MOD=1e9+7;
const int N=1000100;void init() {}mt19937 rng(chrono::steady_clock::now().time_since_epoch().count());
int Base = uniform_int_distribution<>(8e8,9e8)(rng);int a[N];vector<int>G[N];
int num;
int vis[N];void dfs(int t){vis[t]=1;num++;for(int i=0;i<G[t].size();i++) {int son = G[t][i];if(!vis[son]) {dfs(son);}}if(G[t].size() != 2) num = MOD;
}void solve() {init();int n,m;cin>>n>>m;for(int i=1;i<=m;i++) {int u,v;cin>>u>>v;G[u].push_back(v);G[v].push_back(u);}if(m != n) {cout<<"No\n";return ;}dfs(1);if(num != n) cout <<"No\n";else cout<<"Yes\n";
}signed main() {//ios::sync_with_stdio(false);//cin.tie(0);//cout.tie(0);//cout<<prime[cnt-1]<<"\n";//for(int i=1;i<=cnt;i++) cout<<prime[i]<<"\n";int t=1;//cin>>t;while(t--) {solve();}return 0;
}
D - Goin’ to the Zoo
有n个动物园以及m个动物,告诉你每个动物在哪些动物园都有,每次去第i个动物园都需要支付 C i C_i Ci元,多次去同一个动物园看同一个动物视为看了某个动物多次,问你最少需要多少元能够满足每个动物至少都看了两次
刚开始我只想着简单的做法,所以小卡了一手这个地方,后面看范围越看越感觉能暴力。仔细一算,3的10次方大概1e4,完全可以直接爆搜,然后就用爆搜的做法过了
由于每个动物只需要看两次,也就是说我最多去同一个动物园两次,所以我只需要暴力搜索去某个动物园2次,1次,0次的情况就好
代码如下:
#include<bits/stdc++.h>using namespace std;
#define int long long
const int N=1000100;
const int MOD=1e9+7;
vector<int>G[N];
vector<int>H[N];
int vis[N];
int n,m;
int minvalue = 20 * MOD;
int cost;
int a[N];void dfs(int t)
{//cout<<t<<"||"<<cost<<"\n";if(t == n+1){int sign=1;for(int i=1;i<=m;i++){if(vis[i] < 2){sign = 0;break;}}if(sign) minvalue = min(minvalue,cost);return ;}//去两次动物园的情况 for(int i=0;i<G[t].size();i++){int v = G[t][i];vis[v]+=2;}cost += a[t] * 2;dfs(t+1);cost -= a[t];//去一次动物园的情况 for(int i=0;i<G[t].size();i++){int v = G[t][i];vis[v]--;}dfs(t+1);cost -= a[t];//去零次动物园的情况 for(int i=0;i<G[t].size();i++){int v = G[t][i];vis[v]--;}dfs(t+1);
}void solve()
{cin>>n>>m;for(int i=1;i<=n;i++) cin>>a[i];map< pair<int,int> , int>mp;for(int i=1;i<=m;i++){int num;cin>>num;for(int j=1;j<=num;j++){int v;cin>>v;if(!mp[{v,i}]) G[v].push_back(i),mp[{v,i}]=1;}}// for(int i=1;i<=n;i++)
// {
// for(int j=0;j<G[i].size();j++) cout<<G[i][j]<<" ";
// cout<<"\n";
// }dfs(1);cout<<minvalue;
}signed main()
{int t=1;while(t--){solve();}return 0;
}
E - Bowls and Beans
给你n个碗,每个碗都有一个对应的 C i C_i Ci,初始时候每个碗里面都有 a i a_i ai个豆,每次操作你都可以将某个碗里面豆移动到这个碗左边 C i C_i Ci个碗中,问你最少需要多少次操作能够将所有豆移动到第一个碗里面
关于这道题我们需要理清一下思绪,首先先看某一个豆移动到第一个碗的操作,我每次遍历我当前能够到达的范围范围1,然后再遍历这个范围1,找到这个范围里面每个碗能够移动的最左边得到范围2,然后再让范围1扩张为范围2,重复操作,我所进行的操作次数就是只看这一个豆的情况下所需要的操作次数
那可能就有人要问了,为什么不是bfs去找层次呢,所以接下来就是重点,当我多个豆到达同一个碗,接下来我只需要一次操作就能将这些豆移走,也就是说我知道多个豆在哪个位置进入同一个碗,这是bfs难以做到的一点
考虑到以上这一点,我们不难得知一点:当左边的豆已经找到最短移动到第一个碗的时候,对于当前这个豆,我们只需要用最少的操作次数移动到前面已经找到最短移动路径即可
那么我们代码部分应该如何打呢,那我们就需要从左边开始遍历,当这个碗里面有豆的时候,我们不断重复前面提到的只看某一个豆的移动,一直重复到我可以移动到第一个碗或者是已经找到最短路径的碗即可
代码如下:
#include<bits/stdc++.h>using namespace std;#define int long long
#define lowbit(x) x&(-x)const int MOD=1e9+7;
const int N=1000100;mt19937 rng(chrono::steady_clock::now().time_since_epoch().count());
int Base = uniform_int_distribution<>(8e8,9e8)(rng);int a[N];
int c[N];void solve() {init();int n;cin>>n;for(int i=1;i<=n-1;i++) cin>>c[i];for(int i=1;i<=n-1;i++) cin>>a[i];int res=0;int pre=0;for(int i=1;i<=n;i++) {if(a[i]) {int left = i,right=i;while(left > pre) {res ++;int nxtleft=left;for(int j=left;j<=right;j++) {nxtleft = min(nxtleft,j - c[j]);}left = nxtleft;}pre = i;}}cout<<res<<"\n";
}signed main() {//ios::sync_with_stdio(false);//cin.tie(0);//cout.tie(0);//cout<<prime[cnt-1]<<"\n";//for(int i=1;i<=cnt;i++) cout<<prime[i]<<"\n";int t=1;//cin>>t;while(t--) {solve();}return 0;
}
相关文章:
AtCoder Beginner Contest 404 A-E 题解
还是ABC好打~比ARC好打多了( 题解部分 A - Not Found 给定你一个长度最大25的字符串,任意输出一个未出现过的小写字母 签到题,map或者数组下标查询一下就好 #include<bits/stdc.h>using namespace std;#define int long long #def…...
WiFi出现感叹号上不了网怎么办 轻松恢复网络
在日常生活中,WiFi已成为不可或缺的一部分。然而,有时我们会遇到WiFi图标上出现了感叹号,无法上网。无论是办公、学习还是娱乐,这种情况都会严重影响体验。这种情况该怎么解决呢?本期驱动哥就给各位介绍几种简单的解决…...
M0芯片的基础篇Timer
一、计数器的原理 加法计数器 减法计数器 触发中断 最短计时时间 时钟周期决定 16bit 65535 最长计时时间 时间周期和最大计数值决定 二、syscfg配置 timg:通用定时器 tima:高级定时器 timx:不论是高级定时器还是通用定时器都是一样…...
vue教程(vuepress版)
Vue 完全指南 项目介绍 这是一个系统化的 Vue.js 学习教程,采用循序渐进的方式,帮助开发者从零开始掌握 Vue 开发技能。 教程特点 循序渐进: 从 Vue 基础概念开始,逐步深入到高级特性,适合不同层次的开发者学习实战驱动: 结合…...
【嵌入式开发-USB】
嵌入式开发-USB ■ USB简介 ■ USB简介...
【前端】webstorm运行程序浏览器报network error
是浏览器阻止了链接,先把能正常访问的链接搜索,禁止访问的时候,高级,强制访问,再运行项目生成的网址就可以了。...
国内led显示屏厂家以及售后 消费对比与选择
国内led显示屏的厂家有很多,虽然让消费者在选择的时候有了多种的机会,可是在质量方面的鉴别上也是无从下手。对此为了方便消费者作出选择,下面为您推荐一些品牌厂家。 1、强力巨彩 是全球比较有名气的LED显示屏厂家的制造商,总厂房…...
【Go】优化文件下载处理:从多级复制到零拷贝流式处理
在开发音频处理服务过程中,我们面临一个常见需求:从网络下载音频文件并保存到本地。这个看似简单的操作,实际上有很多优化空间。本文将分享一个逐步优化的过程,展示如何从一个基础实现逐步改进到高效的流式下载方案。 初始实现&a…...
驱动开发硬核特训 · Day 30(上篇):深入理解 I2C 总线驱动模型(以 at24 EEPROM 为例)
作者:嵌入式Jerry 视频教程请关注 B 站:“嵌入式Jerry” 一、写在前面 在上一阶段我们已经深入理解了字符设备驱动与设备模型之间的结合方式、sysfs 的创建方式以及平台驱动模型的实际运用。今天我们迈入总线驱动模型的世界,聚焦于 I2C 总线…...
LaTeX印刷体 字符与数学符号的总结
1. 希腊字母(Greek Letters) 名称小写 LaTeX大写 LaTeX显示效果Alpha\alphaAαα, AABeta\betaBββ, BBGamma\gamma\Gammaγγ, ΓΓDelta\delta\Deltaδδ, ΔΔTheta\theta\Thetaθθ, ΘΘPi\pi\Piππ, ΠΠSigma\sigma\Sigmaσσ, ΣΣOmega\omeg…...
关键字where
C# 中的 where 关键字主要用在泛型约束(Generic Constraints)中,目的是对泛型类型参数限制其必须满足的条件,从而保证类型参数具备特定的能力或特性,增强类型安全和代码可读性。 约束写法说明适用场景举例C#版本要求w…...
vite 代理 websocket
🛡️一、WebSocket 基本概念 名称全称含义使用场景ws://WebSocket非加密的 WebSocket 连接开发环境、内网通信wss://WebSocket Secure加密的 WebSocket 连接(基于 TLS/SSL)生产环境、公网通信 🛡️二、安全性对比 特性ws://wss…...
深入理解操作系统:从基础概念到核心管理
在计算机系统中,操作系统是至关重要的组成部分,它如同计算机的“大管家”,统筹协调着系统的各项资源与工作流程。接下来,就让我们深入了解操作系统的奥秘。 一、操作系统概述 操作系统能有效组织和管理系统中的软/硬件资源&…...
手撕基于AMQP协议的简易消息队列-1(项目介绍与开发环境的搭建)
项目绍 码云仓库:MessageQueues: 仿Rabbit实现消息队列 文章概要 本文将介绍从零搭建一个简易消息队列的方法,目的是了解并学习消息队列的底层原理与逻辑,编写一个独立的服务器程序。从搭建开发环境开始,到编写一些工作组件&am…...
C++ 模板方法模式详解与实例
模板方法模式概念 模板方法模式(Template Method Pattern)属于行为型设计模式,其核心思想是在一个抽象类中定义一个算法的骨架,而将一些步骤延迟到子类中实现。这样可以使得子类在不改变算法结构的情况下,重新定义算法中的某些步骤。它通过继承机制,实现代码复用和行为…...
北京丰台人和中医院,收费贵吗?
北京丰台人和中医院,收费贵吗? 北京丰台人和中医院属于平价医院,百姓医院,收费不贵,北京丰台人和中医院35年专业看肝病,之所以能够在肝病感染者中赢得广泛好评,离不开其严谨的医疗流程、专业的…...
21、魔法传送阵——React 19 文件上传优化
一、魔法传送阵的核心法则 1.量子切割术(分片上传) const sliceFile (file) > {const chunks [];let start 0;const CHUNK_SIZE 2 * 1024 * 1024; // 2MB分片while (start < file.size) {chunks.push({id: ${file.name}-${start},data: file.s…...
Windows命令行软件管理器:Chocolatey
文章目录 Windows命令行软件管理器:Chocolatey1.Chocolatey使用1.1 安装1.2 常用命令1.3 使用流程 2.常用shell命令汇总 Windows命令行软件管理器:Chocolatey Chocolatey 是一款强大的 Windows 命令行软件管理器,目前在 GitHub 上已斩获 10.…...
【MySQL】第二弹——MySQL表的增删改查(CRUD)
文章目录 🎓一. CRUD🎓二. 新增(Create)🎓三. 查询(Rertieve)📖1. 全列查询📖2. 指定列查询📖3. 查询带有表达式📖4. 起别名查询(as )📖 5. 去重查询(distinct)📖6. 排序…...
Windows环境,Python实现对本机处于监听状态的端口,打印出端口,进程ID,程序名称
1、pip install tabulate 2、代码实现 #!/usr/bin/env python # -*- coding: utf-8 -*-""" Windows端口监听程序 显示本机处于监听状态的端口,进程ID和程序名称 """import subprocess import re import os import sys from tabulat…...
什么是变量提升?
变量提升(Hoisting) 是 JavaScript 引擎在代码执行前的一个特殊行为,它会将变量声明和函数声明自动移动到当前作用域的顶部。但需要注意的是,只有声明会被提升,赋值操作不会提升。 核心概念 变量声明提升&…...
Java大师成长计划之第15天:Java线程基础
📢 友情提示: 本文由银河易创AI(https://ai.eaigx.com)平台gpt-4o-mini模型辅助创作完成,旨在提供灵感参考与技术分享,文中关键数据、代码与结论建议通过官方渠道验证。 在现代软件开发中,多线程…...
中小企业设备预测性维护:从技术原理到中讯烛龙实践落地指南
在工业 4.0 与智能制造浪潮的推动下,中小企业正面临设备管理模式的深刻变革。传统的事后维修与预防性维护策略,因缺乏数据驱动与智能决策能力,已难以满足企业降本增效的核心诉求。据 Gartner 统计,非计划停机导致的生产损失平均每…...
mysql 复习
mysql定义与架构 数据库是按照数据结构来组织、存储和管理数据的仓库,方便我们增删查改。MySQL有客户端和服务器端,基于网络服务的,3306端口处于监听状态。 数据库的存储介质有以下两种: 磁盘,比如MySQL就是一种磁盘…...
高低比率策略
本策略的核心在于运用技术指标结合基本规则进行交易决策,旨在通过高低比率策略捕捉市场的超买和超卖信号,以此指导交易行为。 一、交易逻辑思路 1. 指标计算: - 本策略首先通过EMA(指数移动平均)计算快线和慢线的值&am…...
python线上学习进度报告
一、mooc学习 二、python123学习...
深入剖析ThreadLocal:原理、应用与最佳实践
深入剖析ThreadLocal:原理、应用与最佳实践 一、ThreadLocal的本质与价值 1.1 什么是ThreadLocal? ThreadLocal是Java提供的线程本地变量机制,允许每个线程拥有独立的变量副本,实现线程间的数据隔离。它通过“空间换时间”的方式…...
nginx 配置后端健康检查模块
nginx自带的针对后端节点健康检查的功能比较简单,通过默认自带的ngx_http_proxy_module 模块和ngx_http_upstream_module模块中的参数来完成,当后端节点出现故障时,自动切换到健康节点来提供访问。但是nginx不能事先知道后端节点状态是否健康,后端即使有不健康节点,负载均…...
路由交换实验
案例一:实施和配置RIPV2 1.给AR1配置接口 查看R1接口配置情况 2.配置三台路由的RIP协议,版本为version2 ,关闭自动汇总,通告所有的直连接口 案例二:配置多区域的OSPF协议 1.配置R1的接口IP地址参数 2.配置r2,r3的接口参…...
主成分分析(PCA)是什么?简易理解版
文章目录 一、PCA的本质与核心价值二、数据中的"重要方向":理解变异性三、主成分的数学基础四、荷载向量的深入理解五、PCA的计算过程详解5.1 数据预处理5.2 计算协方差矩阵5.3 特征分解5.4 主成分得分计算 六、PCA的实际应用解读七、PCA的工具与实现7.1 …...
Linux常用命令34——uname显示系统内核信息
在使用Linux或macOS日常开发中,熟悉一些基本的命令有助于提高工作效率,uname命令来自英文词组UNIX name的缩写,其功能是查看系统主机名、内核及硬件架构等信息。如果不加任何参数,默认仅显示系统内核名称(相当于-s参数…...
Linux下使用openssh搭建sftp服务
创建 SFTP 用户组 为 SFTP 用户创建一个专用组: sudo groupadd sftpusers 创建 SFTP 用户 创建 SFTP 用户并将其添加到 sftpusers 组,同时指定用户的主目录和禁止 shell 访问: sudo useradd -g sftpusers -s /sbin/nologin username sud…...
C++ 复习(一)
命名空间 概念 : 命名空间的主要作用是创建一个新的作用域 里面可以放函数 变量 定义 为了防止命名冲突 实现 : 通过使用namespace 空间名 {} 在大括号中添加 内容 1. 这里命名空间允许嵌套 2. 在同一个工程中允许存在多个同名的命名空间 在最后编译…...
主备Smart Link + Monitor Link组网技术详细配置
1.实验拓扑 2.使用设备 eNSP模拟建议下行设备三台使用S3700模拟(全部使用S5700可能会出现流量丢失等异常问题。) 3.实验配置 [SW1]dis cu # sysname SW1 # vlan batch 100 110 # interface Ethernet0/0/1port link-type accessport default vlan 100 …...
【5G通信】redcap和bwp 随手记
在5G通信中,BWP(Bandwidth Part)是一种技术,允许终端设备在不同的带宽部分上进行通信,从而提高频谱效率和灵活性。BWP可以分为初始BWP(Initial BWP)、默认BWP(Default BWP࿰…...
第三天 车联网云架构
一、车联网技术演进与行业变革 1.1 从传统Telematics到智能网联汽车 当我们驾驶着搭载智能网联系统的汽车时,车辆每秒会产生超过1GB的数据流量。这些数据包括: 高精度地图的实时更新ADAS传感器采集的环境信息车载娱乐系统交互数据车辆状态监控信息 传…...
手撕基于AMQP协议的简易消息队列-7(客户端模块的编写)
在MQClient中编写客户端模块代码 在MQClient中编写makefile文件来编译客户端模块 .PHONY:all all:PublichClient ConsumeClient PublichClient : PublichClient.cpp ../MQCommon/request.pb.cc ../MQCommon/message.pb.cc ../ThirdLib/lib/include/muduo/protobuf/codec.ccg …...
Spring Security(笔记)
第一步: 首先使用Intellij IDEA创建一个Spring Boot项目,JDK选择自己安装的1.8。点击Next后,编辑项目信息。然后跳转到选择依赖页面。 第二步: 添加Spring Security、Spring Web、Thymeleaf三个依赖。完成后等待项目构建完成。…...
通义灵码编码插件支持MCP
通义灵码MCP功能集成概述 通义灵码已深度集成魔搭社区(ModelScope)的MCP(Model Context Protocol)服务,为开发者提供了在IDE中直接调用AI能力的便捷通道。MCP作为标准化协议,通过定义Resources、Prompts和…...
问题 | 当前计算机视觉迫切解决的问题
当前计算机视觉领域虽然在技术上取得了显著进展,但仍面临一系列关键挑战。结合最新研究与应用现状,以下是最迫切需要解决的几大问题: 1. 数据质量与多样性不足 高质量标注数据的获取:训练高效模型依赖大量精准标注的数据&#x…...
C++ STL入门:vecto容器
C STL 系列入门:vector 动态数组 一、vector 容器核心特性 vector 是 C 标准库提供的动态数组容器,具有以下显著优势: 自动扩容机制:当插入元素超出当前容量时,自动申请新内存并迁移数据随机访问效率:支持…...
Java 线程全面概述
Java 线程全面概述 线程是程序执行的最小单元,是操作系统能够调度的最小单位。Java 提供了完善的线程支持,下面从基础概念到高级特性进行全面解析。 一、线程基础概念 1. 线程 vs 进程 特性进程线程资源占用独立内存空间共享进程内存切换成本高&#…...
高效文件夹迁移工具,轻松实现批量文件管理
软件介绍 DirMapper是一款专注于文件夹迁移的工具,可以快速完成文件的批量整理与位置调整。 功能特点 这款文件夹迁移工具提供两种操作模式:复制模式和移动模式,用户可以根据需求自行选择。如果需要保留原文件,可以选择复…...
sherpa:介绍
更多内容:XiaoJ的知识星球 目录 1. sherpa 介绍 1. sherpa 介绍 sherpa是 Next-gen Kaldi 项目的部署框架。 sherpa 支持在各种平台上部署与语音相关的预训练模型,并提供多种语言绑定。 目前,sherpa 拥有以下子项目: k2-fsa/sh…...
Android Studio Gradle 中 只显示 Tasks 中没有 build 选项解决办法
一、问题描述 想把项目中某一个模块的代码单独打包成 aar ,之前是点击 AndroidStudio 右侧的 Gradle 选项,然后再点击需要打包的模块找到 build 进行打包,但是却发现没有 build 选项。 二、解决办法 1、设置中勾选 Configure all Gradle tasks… 选项 …...
手撕基于AMQP协议的简易消息队列-6(服务端模块的编写)
在MQServer中编写服务端模块代码 在MQServer中编写makefile文件来编译服务端模块 .PHONY: server CFLAG -I../ThirdLib/lib/include LFLAG -L../ThirdLib/lib/lib -lgtest -lprotobuf -lsqlite3 -pthread -lmuduo_net -lmuduo_base -lz server:server.cpp ../MQCommon/messag…...
面试实践AND面经热点题目总结
1、对于Rocketmq消息积压、丢失如何解决? 消息积压原因以及解决方案 🎯 产生原因: 消费者处理能力弱,消费速度远低于生产速度; 网络不稳定,消费者拉取消息失败; 消费端异常(如处理…...
MySQL基础关键_012_事务
目 录 一、概述 二、ACID 四大特性 三、MySQL 事务 四、事务隔离级别 1.说明 2.现象 (1)脏读 (2)不可重复读 (3)幻读 3.查看隔离级别 4.设置隔离级别 5.隔离级别 (1)初始…...
Missashe考研日记-day35
Missashe考研日记-day35 1 专业课408 学习时间:3h学习内容: 完结撒花!!今天把OS最后一节的内容学完了,操作系统也算是告一段落了,接下来是计网时间!不过计网我是上学期才学过的,当…...
如何添加二级域名
在 华为云 上添加二级域名(如 sub.example.com)主要涉及 DNS解析配置 和 服务器绑定 两个步骤。以下是详细操作指南: 一、前提条件 已拥有 主域名(如 example.com)并完成 ICP备案(若服务器在中国大陆&#…...