【一百零一】【算法分析与设计】差分,1109. 航班预订统计,P4231 三步必杀,P5026 Lycanthropy

news2025/1/20 14:49:19

1109. 航班预订统计

这里有 n 个航班,它们分别从 1n 进行编号。

有一份航班预订表 bookings ,表中第 i 条预订记录 bookings[i] = [first(i), last(i), seats(i)] 意味着在从 first(i)last(i)包含 first(i)last(i) )的 每个航班 上预订了 seats(i) 个座位。

请你返回一个长度为 n 的数组 answer,里面的元素是每个航班预定的座位总数。

示例 1:

输入:bookings = [[1,2,10],[2,3,20],[2,5,25]], n = 5 输出:[10,55,45,25,25] 解释: 航班编号 1 2 3 4 5 预订记录 1 : 10 10 预订记录 2 : 20 20 预订记录 3 : 25 25 25 25 总座位数: 10 55 45 25 25 因此,answer = [10,55,45,25,25]

示例 2:

输入:bookings = [[1,2,10],[2,2,15]], n = 2 输出:[10,25] 解释: 航班编号 1 2 预订记录 1 : 10 10 预订记录 2 : 15 总座位数: 10 25 因此,answer = [10,25]

提示:

  • 1 <= n <= 2 * 10(4)

  • 1 <= bookings.length <= 2 * 10(4)

  • bookings[i].length == 3

  • 1 <= first(i) <= last(i) <= n

  • 1 <= seats(i) <= 10(4)

1.

差分,arr数组,需要完成一些操作,例如区间[l,r]加c操作.

将arr数组进行一系列的add操作,add(l,r,c)表示区间[l,r]统一加上c.

2.

add(l,r,c)操作,只需要arr[l]+=c,arr[r+1]-=c.

3.

进行一系列的add操作后,求arr的前缀和,结果是我们想要的答案.

4.

将arr数组中0~3区间加上1,2~5区间加上2,3~6区间加上-1.

很容易可以得到答案是1,1,3,2,1,1,-1.

利用差分,步骤是arr[0]+=1,arr[3+1]-=1.

arr[2]+=2,arr[5+1]-=2.

arr[3]+=-1,arr[6+1]-=-1.

然后arr求前缀和,得到的就是答案.

5.

对arr数组进行操作的意义是,+=表示添加影响,-=表示影响消失.

例如0~3区间加上1,arr[0]+=1表示从下标0开始都要加上1,开始影响.

以直到3+1=4下标影响结束,所以需要-=1.

6.

前缀和计算出影响的结果.

代码

 
// #define DEBUG
#ifdef DEBUG
#define BUG(code) do{code}while(0)
#else
#define BUG(code) do{}while(0)
#endif

class Solution {
public:
    vector<int> ret; // 用于存储最终的航班预订座位数
    vector<vector<int>> bookings; // 存储航班预订记录
    int n; // 航班数量
    vector<int> arr; // 差分数组,用于记录区间加减操作

    void solve() {
        ret.assign(n, 0); // 初始化结果数组,长度为n,初始值为0
        arr.assign(n + 1, 0); // 初始化差分数组,长度为n+1,初始值为0
        for (auto& x : bookings) { // 遍历每条预订记录
            int left = x[0] - 1, right = x[1] - 1, nums = x[2]; // 提取预订记录中的起始航班、结束航班和预订座位数
            arr[left] += nums; // 在差分数组中起始位置加上预订座位数
            arr[right + 1] -= nums; // 在差分数组中结束位置的下一个位置减去预订座位数
        }
        for (int i = 0; i < n; i++) { // 计算前缀和得到每个航班的预订座位总数
            ret[i] = (i - 1 >= 0 ? ret[i - 1] : 0) + arr[i]; // 当前航班的预订座位数等于前一个航班的预订座位数加上当前差分数组的值
            // BUG(cout << ret[i] << endl;); // 如果启用DEBUG模式,输出当前航班的预订座位数
            BUG(cout << arr[i] << endl;); // 如果启用DEBUG模式,输出当前差分数组的值
        }
    }

    vector<int> corpFlightBookings(vector<vector<int>>& _bookings, int _n) {
        ios::sync_with_stdio(0), cin.tie(0), cout.tie(0); // 优化输入输出
        bookings = _bookings, n = _n; // 将输入参数赋值给类成员变量
        solve(); // 调用solve函数处理预订记录
        return ret; // 返回结果数组
    }
};

;

P4231 三步必杀

三步必杀

题目背景

(三)旧都

离开狭窄的洞穴,眼前豁然开朗。

天空飘着不寻常的雪花。

一反之前的幽闭,现在面对的,是繁华的街市,可以听见酒碗碰撞的声音。

这是由被人们厌恶的鬼族和其他妖怪们组成的小社会,一片其乐融融的景象。

诶,不远处突然出现了一些密密麻麻的小点,好像大颗粒扬尘一样。

离得近了点,终于看清楚了。

长着角的鬼们聚在一起,围观着另一只鬼的表演。

那”扬尘”,其实都是弹幕。

勇仪的招数之一,三步之内,所到之处弹幕云集,几乎没有生存可能。

为了强化这一技能,勇仪将对着一排柱子进行攻击。

旧地狱的柱子虽然无比坚固,但保险起见还是先要了解一下这样一套攻击对柱子有多少损伤,顺带也能检验练习的效果。

勇仪决定和其它鬼们商量商量...

“我知道妖怪之山的河童一族有一种叫做计算机的神奇道具,说不定可以借来用用”,萃香说道。

于是旧地狱的鬼族就决定请河城荷取来帮忙了。

“要记录【所有柱子的损伤程度】吗”,荷取问道。

经过进一步的询问,荷取发现他们仅仅需要【所有攻击都完成后】柱子的损伤程度。

任务了解地差不多了,荷取将其中的重要部分提取了出来,记录在了她的工作笔记本上:

(记录的内容见题目描述)

那么实验就这样开始了。

在惊天动地的碰撞声中,勇仪每完成一轮攻击,荷取都忠实地记录下对每根柱子产生的伤害。而此时勇仪就在旁边等待着记录完成,然后再进行下一轮的攻击。

地面上,天色渐晚。

“不想在这里留到深夜啊,不然就回不了家了”,荷取这样想着,手中依然在重复地向计算机中输入新产生的信息。

“真的必须一次一次地记录下每轮攻击对每个柱子产生的伤害吗?有没有更高效的方法?”这一念头在荷取的心中闪过...

(后续剧情在题解中,接下来请看T3)

题目描述

问题摘要:

$$$$个柱子排成一排,一开始每个柱子损伤度为0。

接下来勇仪会进行$M$次攻击,每次攻击可以用4个参数$l$,$r$,$s$,$e$来描述:

表示这次攻击作用范围为第$l$个到第$r$个之间所有的柱子(包含$l$,$r$),对第一个柱子的伤害为$s$,对最后一个柱子的伤害为$e$。

攻击产生的伤害值是一个等差数列。若$l=1$,$r=5$,$s=2$,$e=10$,则对第1~5个柱子分别产生2,4,6,8,10的伤害。

鬼族们需要的是所有攻击完成之后每个柱子的损伤度。

输入格式

第一行2个整数$N$,$M$,用空格隔开,下同。

接下来$M$行,每行4个整数$l$,$r$,$s$,$e$,含义见题目描述。

数据保证对每个柱子产生的每次伤害值都是整数。

输出格式

由于输出数据可能过大无法全部输出,为了确保你真的能维护所有柱子的损伤度,只要输出它们的异或和与最大值即可。

(异或和就是所有数字按位异或起来的值)

(异或运算符在c++里为^)

样例 #1

样例输入 #1

5 2 1 5 2 10 2 4 1 1

样例输出 #1

3 10

样例 #2

样例输入 #2

6 2 1 5 2 10 2 4 1 1

样例输出 #2

3 10

提示

样例解释:

样例1:

第一次攻击产生的伤害:2 4 6 8 10

第二次攻击产生的伤害:0 1 1 1 0

所有攻击结束后每个柱子的损伤程度:2 5 7 9 10。

输出异或和与最大值,就是3 10。

样例2:

没有打到第六根柱子,答案不变

数据范围:

本题满分为100分,下面是4个子任务。(x/y)表示(得分/测试点数量)

妖精级(18/3):$1\leqslant n$,$m\leqslant1000$。这种工作即使像妖精一样玩玩闹闹也能完成吧?

河童级(10/1):$s=e$,这可以代替我工作吗?

天狗级(20/4):$1\leqslant n\leqslant10^5$,$1\leqslant m\leqslant10^5$。小打小闹不再可行了呢。

鬼神级(52/2):没有特殊限制。要真正开始思考了。

以上四部分数据不相交。

对于全部的数据:$1\leqslant n\leqslant10^7$,$1\leqslant m\leqslant3\times 10^5$,$1\leqslant l<r\leqslant n$.

所有输入输出数据以及柱子受损伤程度始终在$[0,9\times 10^{18}]$范围内。

提示:

由于种种原因,时间限制可能会比较紧,C++选手请不要使用cin读入数据。

by orangebird

1.

代码

 
#include<bits/stdc++.h> // 包含所有C++标准库头文件
using namespace std;

#define int long long // 定义int为long long类型,方便处理大整数
#define endl '\n' // 定义endl为换行符,简化代码
#define FAST() ios::sync_with_stdio(0),cin.tie(0),cout.tie(0); // 优化输入输出,加快执行速度

#define p pair<int,int> // 定义p为pair<int, int>类型,简化代码
#define ff first // 定义ff为first,简化pair的使用
#define ss second // 定义ss为second,简化pair的使用

#define ltu(i,a,b) for(int i=a;i<=b;i++) // 定义从a到b的递增循环
#define utl(i,a,b) for(int i=a;i>=b;i--) // 定义从a到b的递减循环
#define tests() int t;cin>>t;while(t--) // 定义多组测试数据的输入方式

int n, m; // n为柱子的数量,m为攻击次数
struct node { // 定义结构体node用于存储攻击信息
    int l, r, s, e; // l为起始柱子,r为结束柱子,s为起始伤害,e为结束伤害
};
vector<node> readd; // 存储所有攻击的向量
vector<int> arr; // 差分数组,用于记录伤害
int ret_max; // 记录所有柱子中最大损伤度
int ret; // 记录所有柱子的损伤度的异或和

void solve() {
    ret = 0; // 初始化异或和为0
    ret_max = LLONG_MIN; // 初始化最大损伤度为最小的long long值
    arr.assign(n + 5, 0); // 初始化差分数组,大小为n+5,初始值为0
    for (auto& x : readd) { // 遍历每一个攻击记录
        int d = (x.e - x.s) / (x.r - x.l); // 计算等差数列的公差
        arr[x.l] += x.s; // 在起始位置增加初始伤害
        arr[x.l + 1] += d - x.s; // 在起始位置的下一位增加公差减去初始伤害
        arr[x.r + 1] += -d - x.e; // 在结束位置的下一位减少公差和结束伤害
        arr[x.r + 2] += x.e; // 在结束位置的下两位增加结束伤害
    }

    ltu(i, 1, n) { // 第一次构建前缀和
        arr[i] = (i - 1 >= 0 ? arr[i - 1] : 0) + arr[i]; // 前缀和累加
    }
    ltu(i, 1, n) { // 第二次构建前缀和
        arr[i] = (i - 1 >= 0 ? arr[i - 1] : 0) + arr[i]; // 前缀和累加
        ret_max = max(ret_max, arr[i]); // 更新最大损伤度
        ret ^= arr[i]; // 计算损伤度的异或和
    }
    cout << ret << " " << ret_max << endl; // 输出异或和和最大损伤度
}

signed main() {
    FAST(); // 优化输入输出
    cin >> n >> m; // 输入柱子数量和攻击次数
    readd.clear(); // 清空攻击记录向量
    ltu(i, 1, m) { // 输入每一条攻击记录
        node temp = node(); // 定义临时变量存储攻击信息
        cin >> temp.l >> temp.r >> temp.s >> temp.e; // 输入攻击信息
        readd.push_back(temp); // 将攻击信息加入向量
    }
    solve(); // 调用solve函数计算结果
}

P5026 Lycanthropy

Lycanthropy

题目背景

小正方形亲眼看见了自己昔日的朋友被卷进了黑暗的深渊,然而它无力阻止……

现在它的朋友已经向它发起了攻击,因此小正方形不得不抵抗。

题目描述

我们把山顶上的湖泊看作一条长度为 $$$$ 的直线,一开始水深都在水平线上,我们视作此时的水深为 '0'

接下来,在一瞬间,小正方形的"朋友"们跳起并扎入水中,导致在入水点的水降低而远离入水点的水升高,注意两个 "朋友" 可能在同一地点入水。

小正方形的每个朋友有一个体积数值 $v$,当体积为 $$$$ 的一个朋友跳入水中,我们设入水点为 $i$,将会导致 $$i - v + $$ 到 $$$$ 的水位依次降低 $$1,2,\cdots,$$

同样地,第 $$$$ 到 $$i + v - $$ 的水位会依次降低 $v,v - 1,\cdots,1$.

相对应地,$i - v$ 的水位不变, $$i - v - $$ 到 $$i - 2 * $$ 水位依次增加 $1,2,\cdots,v$, $$i - 2 * $$ 到 $$i - 3 * v + $$ 水位依次增加 $$v,v - 1,\cdots,$$

同样,$i + v$ 水位不变,$i + v + 1$ 到 $$i + 2 * $$ 水位增加 $1,2,\cdots,v$,$i + 2 * v$ 到 $$i + 3 * v - $$ 水位依次增加 $$v,v - 1,\cdots,$$

现在小正方形想要穿过这个湖,他想要知道在这 $$$$ 个"朋友"跳入水中后湖上每个节点的水位,你能帮帮它吗?

输入格式

第一行为两个整数 $n$,$m$,表示"朋友"的数目与湖泊的宽度。

接下来 $$$$ 行,一行两个整数 $v,x$,表示第 $$i + $$ 个朋友的体积与入水点。

输出格式

一行 $$$$ 个整数,第 $$$$ 个整数表示 $$$$ 号位的水深。

样例 #1

样例输入 #1

1 10 1 5

样例输出 #1

0 0 1 0 -1 0 1 0 0 0

样例 #2

样例输入 #2

2 10 2 6 3 1

样例输出 #2

-2 0 0 0 0 0 2 2 2 2

提示

对于 $$30\$$ 的数据,$$n <= 50,m <= 50$$

对于 $$70\$$ 的数据,$$n <= 10^5,m <= 10^$$

对于 $$100\$$ 的数据,$$n <= 10^6,m <= 10^6,1 <= v <= 10000,1 <= x <= $$

1.

sett(i-3*v+1,i-2*v,1,v);

sett(i-2*v+1,i,v-1,-v);

sett(i+1,i+2*v,-v+1,v);

sett(i+2*v+1,i+3*v-1,v-1,1);

sett函数有四个参数,sett(l,r,s,e)

表示从区间l~r依次加上等差数列,s到e.

2.

MAXN是湖最大的长度,用于做偏移量.

当我们处理落点x,附近的水高低的时候,处理边界情况很麻烦。

因为可能出现负数,或者可能越界.

因此我们可以开辟大一点的空间,并做一个较大的偏移量,此时不会出现负数也不会越上界

对于每一个区间l~r,做一个偏移量MAXN

"I+=MAXN,r+=MAXN"

3.

build函数计算前缀和.

arr数组开辟的空间大小是2*MAXN+m

原本需要开辟的空间是m左右,然后在前面和后面多开辟一个MAXN

这样就不用考虑边界情况了.

我们需要用到的是1~m偏移一个MAXN的区间位置.

代码

 
#include <bits/stdc++.h> // 包含所有C++标准库头文件
using namespace std;

#define DEBUG
#ifdef DEBUG
#define BUG(code) do{code}while(0)
#else
#define BUG(code) do{}while(0)
#endif // DEBUG

#define int long long // 定义int为long long类型,方便处理大整数
#define endl '\n' // 定义endl为换行符,简化代码
#define FAST() ios::sync_with_stdio(0),cin.tie(0),cout.tie(0) // 优化输入输出,加快执行速度

#define ltu(i,a,b) for(int i=a;i<=b;i++) // 定义从a到b的递增循环
#define utl(i,a,b) for(int i=a;i>=b;i--) // 定义从a到b的递减循环
#define tests() int t;cin>>t;while(t--) // 定义多组测试数据的输入方式

const int MAXN = 1e6 + 10; // 定义常量MAXN,用于数组的大小
int n, m; // n为朋友的数量,m为湖泊的宽度
struct node { // 定义结构体node用于存储朋友的体积和入水点
    int v, x; // v为体积,x为入水点
};
vector<node> readd; // 存储所有朋友信息的向量
vector<int> arr; // 差分数组,用于记录水位变化

void sett(int l, int r, int s, int e) {
    l += MAXN; // 调整左边界,避免负索引
    r += MAXN; // 调整右边界,避免负索引

    int d = (r != l) ? (e - s) / (r - l) : 0; // 计算等差数列的公差
    arr[l] += s; // 在左边界加上初始值s
    arr[l + 1] += d - s; // 在左边界的下一位置加上d-s
    arr[r + 1] += -d - e; // 在右边界的下一位置减去d和e
    arr[r + 2] += e; // 在右边界的下两位置加上e
}

void build() {
    ltu(i, 1, 2 * MAXN + m - 1) { // 构建前缀和
        arr[i] += arr[i - 1]; // 前缀和累加
    }
}

void solve() {
    arr.assign(2 * MAXN + m, 0); // 初始化差分数组,大小为2*MAXN+m,初始值为0

    for (auto& xx : readd) { // 遍历每一个朋友的信息
        int i = xx.x; // 读取入水点
        int v = xx.v; // 读取体积
        sett(i - 3 * v + 1, i - 2 * v, 1, v); // 处理左侧影响
        sett(i - 2 * v + 1, i, v - 1, -v); // 处理左侧与中间的影响
        sett(i + 1, i + 2 * v, -v + 1, v); // 处理中间与右侧的影响
        sett(i + 2 * v + 1, i + 3 * v - 1, v - 1, 1); // 处理右侧影响
    }

    build(); // 构建前缀和
    build(); // 第二次构建前缀和

    ltu(i, MAXN + 1, MAXN + m) { // 输出每个位置的水位
        cout << arr[i] << " "; // 输出水位
    }
    cout << endl; // 输出换行
}

signed main() {
    FAST(); // 优化输入输出
    cin >> n >> m; // 输入朋友的数量和湖泊的宽度
    readd.clear(); // 清空朋友信息向量
    ltu(i, 1, n) { // 输入每一个朋友的信息
        node temp; // 定义临时变量存储朋友信息
        cin >> temp.v >> temp.x; // 输入朋友的体积和入水点
        readd.push_back(temp); // 将朋友信息加入向量
    }
    solve(); // 调用solve函数计算结果
}

结尾

最后,感谢您阅读我的文章,希望这些内容能够对您有所启发和帮助。如果您有任何问题或想要分享您的观点,请随时在评论区留言。

同时,不要忘记订阅我的博客以获取更多有趣的内容。在未来的文章中,我将继续探讨这个话题的不同方面,为您呈现更多深度和见解。

谢谢您的支持,期待与您在下一篇文章中再次相遇!

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

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

相关文章

【ArcGISPro SDK】构建多面体要素

结果展示 每个面构建顺序 代码 using ArcGIS.Core.CIM; using ArcGIS.Core.Data; using ArcGIS.Core.Geometry; using ArcGIS.Desktop.Catalog; using ArcGIS.Desktop.Core; using ArcGIS.Desktop.Editing; using ArcGIS.Desktop.Extensions; using ArcGIS.Desktop.Framework;…

JVM学习-内存泄漏

内存泄漏的理解和分类 可达性分析算法来判断对象是否是不再使用的对象&#xff0c;本质都是判断一上对象是否还被引用&#xff0c;对于这种情况下&#xff0c;由于代码的实现不同就会出现很多内存泄漏问题(让JVM误以为此对象还在引用&#xff0c;无法回收&#xff0c;造成内存泄…

写一个盲盒模拟器

最近想写一个小程序&#xff0c;随便写一个玩吧&#xff0c;先想了下功能&#xff1a; 1.有很多盲盒&#xff0c;可以选择模拟开启 2.自定义盲盒&#xff0c;我们可以自定义制作盲盒自己玩 3.用户界面&#xff0c;记录盲盒历史&#xff0c;可以给坏越提意见 所用技术栈&…

数据库 mysql 的彻底卸载

MySQL卸载步骤如下&#xff1a; &#xff08;1&#xff09;按 winr 快捷键&#xff0c;在弹出的窗口输入 services.msc&#xff0c;打开服务列表。 &#xff08;2&#xff09;在服务列表中&#xff0c; 找到 mysql 开头的所有服务&#xff0c; 右键停止&#xff0c;终止对应的…

拉普拉斯算子

问Chat GPT两种不同拉普拉斯算子的区别&#xff1a;

打印机的ip不同且连不上

打印机的ip不同且连不上 1.问题分析2.修改网段3.验证网络 1.问题分析 主要是打印机的网段和电脑不在同一个网段 2.修改网段 3.验证网络

springcloudalibaba项目注册nacos1.4.2,在nacos上修改配置项不生效问题

背景 之前的项目启动正常,后来发现springcloudalibaba的各版本匹配不正确,于是对项目中的springboot、springcloud、springcloudalibaba版本进行匹配升级,nacos1.4.2匹配的springboot、springcloud、springcloudalibaba版本与我的项目中的版本比较接近,于是我便重新安装了…

汉化PyCharm 2021.1.1 x64超详细教程

1.先打开PyCharm 然后去按住ctrlalts就会打开设置 然后去官网下载 官网地址&#xff1a;Chinese (Simplified) Language Pack / 中文语言包 Plugin for JetBrains IDEs | JetBrains Marketplace 点击进去找到对应的版本进行下载然后将里面的jar包放到 然后重启PyCharm就好了…

Amazon云计算AWS(三)

目录 五、关系数据库服务RDS&#xff08;一&#xff09;RDS的基本原理&#xff08;二&#xff09;RDS的使用 六、简单队列服务SQS&#xff08;一&#xff09;SQS的基本模型&#xff08;二&#xff09;SQS的消息 七、内容推送服务CloudFront&#xff08;一&#xff09;CDN&#…

Anolis OS 8.9服务器使用1PANEL安装部署Halo

前言 昨天我使用Anolis OS 8.9服务器安装部署1PANEL&#xff0c;今天我就来讲讲最强大易用的开源建站工具&#xff1a;Halo 2.16.1的部署。 Halo [ˈheɪloʊ]&#xff0c;意为光环。当然&#xff0c;你也可以当成拼音读(哈喽)。 它轻快&#xff0c;简洁&#xff0c;功能强大。…

SDL教程(二)——Qt+SDL播放器

前言 ​ 这篇文章主要是使用SDL来打开视频&#xff0c;显示视频。后续会再继续使用SDL来结合FFmpeg。来能够直接使用网上的demo进行学习。 正文 一、环境 Qt 5.15.2 MSVC2019 64bit Win11 二、Qt搭建SDL Qt搭建&#xff0c;我觉得相比用VS2019来说&#xff0c;更为方便&…

SD6210A 低噪声可调电荷泵DC/DC转换器芯片IC

一般描述 该SD6210A是一种低噪声&#xff0c;恒定频率(1.20MHz)开关电容电压倍增器。它产生一个调节输出电压从2.8V到5V的输入与高达250mA的输出电流。低外部零件数(一个飞行电容器和两个小旁路电容的VIN和VOUT)使SD6210A非常适合小型&#xff0c;电池供电的应用新的电荷…

揭秘融资融券中的生命线——维持担保比例

01 通俗讲解融资融券 1、融资融券交易&#xff0c;又称信用交易&#xff0c;是指投资者向证券公司提交保证金 ①在看涨时&#xff0c;从证券公司借入资金低价买入证券再高价卖出&#xff1b;&#xff08;加杠杆&#xff09; ②在看跌时&#xff0c;从证券公司借入证券高价卖…

倍福控制电机转速具体实现

倍福控制电机转速 通过PLC代码实现电机的简单控制&#xff08;12分钟&#xff09; 受上面视频的启发&#xff0c;尝试用倍福控制电机转速 中间有一道题做错了&#xff0c;也得亏做错&#xff0c;发现了这个知识点 这里在线修改和查看变量还是值得学习的 查看MC_Jog这个功能块的…

每天的CTF小练--6.5(ascll码高级运用)

题目&#xff1a;[HUBUCTF 2022 新生赛]baby_encrypt hint&#xff1a; 781612443113954655886887407898899451044114412011257135914071455155316031651170318041861191719652013207021272183228423832485254125932643269827992924 注意查看前面的数字&#xff0c;这题不想现…

vue使用tailwindcss

安装依赖 pnpm add -D tailwindcss postcss autoprefixer创建配置文件tailwind.config.js npx tailwindcss init在配置文件content中添加所有模板文件的路径 /** type {import(tailwindcss).Config} */ export default {content: [./index.html, ./src/**/*.{vue,js,ts,jsx,…

英伟达GPU架构加速狂飙

NVIDIA首席执行官黄仁勋在台湾大学体育馆发表主题演讲&#xff0c;展示了新一代Rubin架构&#xff0c;这是NVIDIA加速推出新架构的最新成果。 在讨论NVIDIA下一代架构时&#xff0c;黄仁勋提到了Blackwell Ultra GPU&#xff0c;并表示它可能会继续升级。然后他透露&#xff0c…

NAT端口映射,实现外网访问内网服务器

目录 前言一、搭建网络拓扑1.1 配置server和pc1.1.1 配置server01.1.2 配置server11.1.3 配置pc0 1.2 配置客户路由器1.2.1 配置路由器IP1.2.2 配置静态路由 1.3 配置ISP路由器 二、配置端口映射2.1 在客户路由器配置端口映射2.2 测试公网计算机访问私网服务器2.2.1 PC0向serve…

构建基础网站的入门指南

在数字时代&#xff0c;网站已经成为展示个人、企业或组织信息的重要平台。了解如何通过编写代码来创建一个网站是非常有用的技能。在本文中&#xff0c;我们将了解构建一个基础网站所需的步骤和代码知识。第一步&#xff1a;了解网站的基本组成 一个基本的网站通常包含HTML&a…

变量位置不同会死机?郭天祥老师视频的遗留问题分析答案

在郭天祥老师视频里有一个问题分享&#xff0c;是EXMC初始化里的一个变量定义和初始化位置不同会导致程序死机&#xff0c;最终定位到程序是进入hardfault死机&#xff0c;但暂时没有后续分析了&#xff0c;这里我们来继续分析一下。 死机的程序是这样的&#xff1a; 这段代码…