離散與組合數學 雜記

生成函數

概念

又稱母函數把一個無窮數列 {an}\{a_n\}{an?}(默認從 000 項起)表示成 G(x)=∑i≥0aixiG(x)=\displaystyle\sum_{i\ge0} a_ix^iG(x)=i0?ai?xi 的函數形式。例如:

  • ai=2ia_i=2^iai?=2iG(x)=∑i≥02ixiG(x)=\displaystyle\sum_{i\ge 0} 2^i x^iG(x)=i0?2ixi
  • ai=1a_i=1ai?=1G(x)=∑i≥0xiG(x)=\displaystyle\sum _{i\ge 0} x^iG(x)=i0?xi

應用

用來幫助推導數列的通項公式(比如斐波那契數列)也可以作為條件形式以數列形式給出的象征。一個特別的轉化:逆運用等比數列求和公式,可以得到:11?ax=∑i≥0aixi\displaystyle\dfrac{1}{1-ax}=\sum_{i\ge0}a^ix^i1?ax1?=i0?aixi,等號左邊不帶求和符號部分的,稱為生成函數的封閉形式。

生成函數的乘法運算有意義,其卷積形式是函數直接相乘。對于 A(x)=∑i≥0aixiA(x)=\displaystyle\sum_{i\ge0}a_ix^iA(x)=i0?ai?xiA(x)=∑i≥0bixiA(x)=\displaystyle\sum_{i\ge0}b_ix^iA(x)=i0?bi?xi
A×B=∑i≥0n(xi∑j=0iajbi?j)A\times B=\sum_{i\ge0}^n\left(x^i\sum_{j=0}^ia_jb_{i-j}\right)A×B=i0n?(xij=0i?aj?bi?j?)

洛谷 P10780 BZOJ3028 食物

題意

題目傳送門。

思路

根據上文,將這個背包問題轉化為,考慮每一種物品拿的個數的生成函數,并用封閉形式表示:

  • 偶數個形如 {1,0,1,0,1,......}\{1,0,1,0,1,......\}{1,0,1,0,1,......}∑k≥0x2k=11?x2\displaystyle\sum_{k\ge 0} x^{2k}=\frac{1}{1-x^2}k0?x2k=1?x21?
  • 000111 個形如 {1,1,0,0,0,......}\{1,1,0,0,0,......\}{1,1,0,0,0,......}1+x1+x1+x
  • 000111222 個形如 {1,1,1,0,0,......}\{1,1,1,0,0,......\}{1,1,1,0,0,......}1+x+x21+x+x^21+x+x2
  • 奇數個形如 {0,1,0,1,0,......}\{0,1,0,1,0,......\}{0,1,0,1,0,......}∑k≥0x2k+1=x∑k≥0x2k=x1?x2\displaystyle\sum_{k\ge 0}x^{2k+1}=x\displaystyle\sum_{k\ge 0} x^{2k}=\frac{x}{1-x^2}k0?x2k+1=xk0?x2k=1?x2x?
  • 444 的倍數個類似第一條:∑k≥0x4k=11?x4\displaystyle\sum_{k\ge 0}x^{4k}=\frac{1}{1-x^4}k0?x4k=1?x41?
  • 000111222333 個形如 {1,1,1,0,0,......}\{1,1,1,0,0,......\}{1,1,1,0,0,......}1+x+x2+x31+x+x^2+x^31+x+x2+x3
  • 333 的倍數個類似第一條:∑k≥0x3k=11?x3\displaystyle\sum_{k\ge 0}x^{3k}=\frac{1}{1-x^3}k0?x3k=1?x31?.

全部乘起來,并用二項式定理化簡 1+x+x21+x+x^21+x+x21+x+x2+x31+x+x^2+x^31+x+x2+x3
x(1?x)4\frac{x}{(1-x)^4}(1?x)4x?

考慮推 1(1?x)k=(11?x)k\dfrac{1}{(1-x)^k}=\left(\dfrac{1}{1-x}\right)^k(1?x)k1?=(1?x1?)k 是哪個生成函數的封閉形式與該生成函數的第 nnn 項系數,因為 11?ax=∑i≥0aixi\displaystyle\dfrac{1}{1-ax}=\sum_{i\ge0}a^ix^i1?ax1?=i0?aixia=1a=1a=1 時,11?x=1+x+x2+x3+...\dfrac{1}{1-x}=1+x+x^2+x^3+...1?x1?=1+x+x2+x3+...kkk 次方展開后,相當于選 kkk 個自然數和為 nnn 的方案數:先給 kkk 個數加 111 轉化問題為 kkk 個正整數和為 n+kn+kn+k,運用插板法得知方案數為 (n+k?1k?1)\dbinom{n+k-1}{k-1}(k?1n+k?1?)

回到這一題 1(1?x)4\frac{1}{(1-x)^4}(1?x)41? 的第 n?1n-1n?1 項系數為 (n?23)\dbinom{n-2}{3}(3n?2?),乘回 xxx 后即為答案。代碼略。

Polya 計數

等我完全理解完再回來補。先給結論:用 kkk 中顏色給 nnn 個點的環染色方案數為 1n∑i=0n?1kgcd?(n,i)\dfrac{1}{n}\displaystyle\sum_{i=0}^{n-1}k^{\gcd(n,i)}n1?i=0n?1?kgcd(n,i),可否感性理解呢?

洛谷 P4980 【模板】Pólya 定理

題意

nnn 種顏色給 nnn 個點染色的方案數。兩種方案相同,當且僅當一種方案能夠旋轉變為“另一方案”。

n≤109n\le 10^9n109

思路

問題是如何快速算出 1n∑i=0n?1ngcd?(n,i)\dfrac{1}{n}\displaystyle\sum_{i=0}^{n-1}n^{\gcd(n,i)}n1?i=0n?1?ngcd(n,i)。不妨暴力枚舉 nnn 的約數 d=gcd?(n,i)d=\gcd(n,i)d=gcd(n,i),變為:
1n∑d∣nndφ(nd)\dfrac{1}{n}\displaystyle\sum_{d|n}n^d\varphi(\frac{n}{d})n1?dn?ndφ(dn?)

nnn 太大了不能預處理 φ\varphiφ,記得勤取模。時間復雜度為 T(n)=∑i≥0{O(i)+O(n/i)}=O(n3/4)T(n)=\displaystyle\sum_{i\ge 0}\{O(\sqrt{i})+O(\sqrt{n/i})\}=O(n^{3/4})T(n)=i0?{O(i?)+O(n/i?)}=O(n3/4)(根據主定理推得)。代碼略。

第二類斯特林數

為什么先說第二類,因為第二類好像常用一些。

斯特林數將兩個典型的模型的方案數求解變成一個類似組合數的東西。

概念

{nm}\begin{Bmatrix} n\\ m \end{Bmatrix}{nm?} 表示,將 nnn 個不同的球放進 mmm 個相同的盒子里,且每個盒子都非空的方案數。

其遞推式的推導:

  • nnn 單開一個盒子,那么剩下 n?1n-1n?1 個球放進 m?1m-1m?1 個盒子:{n?1m?1}\begin{Bmatrix} n-1\\ m-1 \end{Bmatrix}{n?1m?1?}
  • nnn 放進非空的 mmm 個盒子:m{n?1m}m\begin{Bmatrix} n-1\\ m \end{Bmatrix}m{n?1m?}

所以 {nm}={n?1m?1}+m{n?1m}\begin{Bmatrix} n\\ m \end{Bmatrix}=\begin{Bmatrix} n-1\\ m-1 \end{Bmatrix}+m\begin{Bmatrix} n-1\\ m \end{Bmatrix}{nm?}={n?1m?1?}+m{n?1m?}

特別的,{n0}=[n=0]\begin{Bmatrix} n\\ 0 \end{Bmatrix}=[n=0]{n0?}=[n=0],中括號表示艾弗森括號。

可以 O(n2)O(n^2)O(n2) 預處理。

應用

先證明其通項公式,發現其滿足下降冪性質:
在這里插入圖片描述
在這里插入圖片描述
在這里插入圖片描述

CF932E Team Work

題意

給定 n,kn,kn,k,求 ∑i=1n(ni)ik\displaystyle\sum_{i=1}^n\dbinom{n}{i}i^ki=1n?(in?)ik

n≤109n\le 10^9n109k≤5000k\le 5000k5000

思路

把組合數用階乘拆開,再運用斯特林數下降冪的性質:

∑i=0nn!i!(n?i)!∑j=0k{kj}i!(i?j)!\sum_{i=0}^n\frac{n!}{i!(n-i)!}\sum_{j=0}^k\begin{Bmatrix} k\\ j \end{Bmatrix}\frac{i!}{(i-j)!}i=0n?i!(n?i)!n!?j=0k?{kj?}(i?j)!i!?

改變 iiijjj 的枚舉順序,iiijjj 開始到 nnn
∑j=0k{kj}∑i=jnn!(n?i)!(i?j)!\sum_{j=0}^k\begin{Bmatrix} k\\ j \end{Bmatrix}\sum_{i=j}^n\frac{n!}{(n-i)!(i-j)!}j=0k?{kj?}i=jn?(n?i)!(i?j)!n!?

強制變成組合數:
∑j=0k{kj}n!(n?j)!∑i=jn(n?j)!(n?i)!(i?j)!\sum_{j=0}^k\begin{Bmatrix} k\\ j \end{Bmatrix}\frac{n!}{(n-j)!}\sum_{i=j}^n\frac{(n-j)!}{(n-i)!(i-j)!}j=0k?{kj?}(n?j)!n!?i=jn?(n?i)!(i?j)!(n?j)!?

∑j=0k{kj}n!(n?j)!∑i=jn(n?ji?j)\sum_{j=0}^k\begin{Bmatrix} k\\ j \end{Bmatrix}\frac{n!}{(n-j)!}\sum_{i=j}^n\binom{n-j}{i-j}j=0k?{kj?}(n?j)!n!?i=jn?(i?jn?j?)

化成 222 次冪形式:
∑j=0k{nm}n!(n?j)!∑i=0n?j(n?ji)\sum_{j=0}^k\begin{Bmatrix} n\\ m \end{Bmatrix}\frac{n!}{(n-j)!}\sum_{i=0}^{n-j}\binom{n-j}{i}j=0k?{nm?}(n?j)!n!?i=0n?j?(in?j?)

∑j=0k{kj}n!(n?j)!×2n?j\sum_{j=0}^k\begin{Bmatrix} k\\ j \end{Bmatrix}\frac{n!}{(n-j)!}\times2^{n-j}j=0k?{kj?}(n?j)!n!?×2n?j

O(k2)O(k^2)O(k2) 時間復雜度預處理第二類斯特林數即可。

代碼

#include<bits/stdc++.h>
using namespace std;
#define ll long long
const ll N=5002,mod=1e9+7;
ll n,k;
ll S2[N][N],p2[N];
ll qpow(ll x,ll k)
{ll ret=1;while(k){if(k&1)ret=ret*x%mod;x=x*x%mod;k>>=1;}return ret;
}
void init()
{S2[0][0]=1;for(int i=1;i<N;i++)for(int j=1;j<N;j++)S2[i][j]=(S2[i-1][j-1]+j*S2[i-1][j]%mod)%mod;
}
int main()
{scanf("%lld%lld",&n,&k);init();ll ans=0;for(int j=0;j<=min(n,k);j++){ll ret=S2[k][j]*qpow(2,n-j)%mod,mul=1;for(int t=n-j+1;t<=n;t++)ret=ret*t%mod;ans=(ans+ret)%mod;}printf("%lld",ans);return 0;
}

第一類斯特林數

概念

[nm]\begin{bmatrix} n\\ m \end{bmatrix}[nm?] 表示,將 nnn 個不同的球擺成 mmm 個環的方案數。兩個環相同,當且僅當一個環通過旋轉可以變成第二個環。

其遞推式的推導:

  • nnn 單開一個環,那么剩下 n?1n-1n?1 個球成 m?1m-1m?1 個環:[n?1m?1]\begin{bmatrix} n-1\\ m-1 \end{bmatrix}[n?1m?1?]
  • nnn 放進 mmm 個環,在放了的 (n?1)(n-1)(n?1) 個球后面都可以放:(n?1)[n?1m](n-1)\begin{bmatrix} n-1\\ m \end{bmatrix}(n?1)[n?1m?]

所以 [nm]=[n?1m?1]+(n?1)[n?1m]\begin{bmatrix} n\\ m \end{bmatrix}=\begin{bmatrix} n-1\\ m-1 \end{bmatrix}+(n-1)\begin{bmatrix} n-1\\ m \end{bmatrix}[nm?]=[n?1m?1?]+(n?1)[n?1m?]

特別的,[nm]=[n=0]\begin{bmatrix} n\\ m \end{bmatrix}=[n=0][nm?]=[n=0],中括號為艾弗森括號。

洛谷 P4609 FJOI2016 建筑師

題意

小 Z 是一個很有名的建筑師,有一天他接到了一個很奇怪的任務:在數軸上建 nnn 個建筑,每個建筑的高度是 111nnn 之間的一個整數。

小 Z 有很嚴重的強迫癥,他不喜歡有兩個建筑的高度相同。另外小 Z 覺得如果從最左邊(所有建筑都在右邊)看能看到 AAA 個建筑,從最右邊(所有建筑都在左邊)看能看到 BBB 個建筑,這樣的建筑群有著獨特的美感。現在,小 Z 想知道滿足上述所有條件的建筑方案有多少種?

如果建筑 iii 的左(右)邊沒有任何建造比它高,則建筑 iii 可以從左(右)邊看到。兩種方案不同,當且僅當存在某個建筑在兩種方案下的高度不同。

1≤n≤50000,1≤A,B≤100,1≤T≤2000001 \leq n \leq 50000, \ 1 \leq A, B \leq 100, \ 1 \leq T \leq 2000001n50000,?1A,B100,?1T200000

思路

中間那個左右都能看見的,高度必然是極值 nnn

除去中間的,左邊要看到 a?1a-1a?1 個,右邊要看到 b?1b-1b?1 個。不妨將能看到的和其左/右邊比它矮的看成 a?1+b?1=a+b?2a-1+b-1=a+b-2a?1+b?1=a+b?2 個環(反正互換位置之后,盡管某些環的元素種類改變,但是環的個數不改變),就可以用第一類斯特林數的含義,將剩下 n?1n-1n?1 和分成 a+b?2a+b-2a+b?2 個環,即 [n?1a+b?2]\begin{bmatrix} n-1\\ a+b-2 \end{bmatrix}[n?1a+b?2?]

然后再 a+b?2a+b-2a+b?2 個環中選各自最大值 a?1a-1a?1 個,成為左邊能看見的(排列方式唯一,必然是從矮到高),即 (a+b?2a?1)\dbinom{a+b-2}{a-1}(a?1a+b?2?)

于是答案為 [n?1a+b?2](a+b?2a?1)\begin{bmatrix} n-1\\ a+b-2 \end{bmatrix}\dbinom{a+b-2}{a-1}[n?1a+b?2?](a?1a+b?2?)

預處理第一類斯特林數即可。

代碼

#include<bits/stdc++.h>
using namespace std;
#define ll long long
const ll N=5e4+9,M=202,mod=1e9+7;
ll T;
ll S1[N][M],fac[N],inv[N];
ll qpow(ll x,ll k)
{ll ret=1;while(k){if(k&1)ret=ret*x%mod;x=x*x%mod;k>>=1;}return ret;
}
void init()
{S1[0][0]=1;for(int i=1;i<N;i++)for(int j=1;j<M;j++)S1[i][j]=(S1[i-1][j-1]+(i-1)*S1[i-1][j]%mod)%mod;fac[0]=1;for(int i=1;i<N;i++)fac[i]=fac[i-1]*i%mod;inv[N-1]=qpow(fac[N-1],mod-2);for(int i=N-2;i>=0;i--)inv[i]=inv[i+1]*(i+1)%mod;
}
ll C(ll n,ll m)
{return fac[n]*inv[m]%mod*inv[n-m]%mod;
}
int main()
{scanf("%lld",&T);init();while(T--){ll n,a,b;scanf("%lld%lld%lld",&n,&a,&b);printf("%lld\n",S1[n-1][a+b-2]*C(a+b-2,a-1)%mod);}return 0;
}

無根樹的 prufer 序列

概念

prufer 序列將節點數為 nnn 的無根樹轉化為長為 n?2n-2n?2 的序列。其表示期望與根的編號無關——定義為每次選擇一個編號最小的葉節點并刪除,然后在序列中記錄其所連接的節點編號,直到剩下兩個節點。

在這里插入圖片描述
如上圖是一棵有 777 個節點的樹的 prufer 序列形成過程。

用 prufer 序列同樣可以還原出一棵樹來。

求法

求一棵樹的 prufer 序列。可以維護每個節點的度數,以節點編號為第一關鍵字扔進堆里排序,當度為 000 時舍棄這個節點。容易做到 O(nlog?n)O(n\log n)O(nlogn)

O(n)O(n)O(n) 的更優秀的算法:“剝葉子”的過程中,每次只會讓其父親節點度數減 111,因此每刪除一個葉節點,至多產生一個新葉節點。

因此可以用一個單調指針 pospospos 維護當前度數為 000 的最小結點,pospospos 枚舉到了先刪 pospospos,然后看 faposfa_{pos}fapos? 是否度數變為 000,如果為 000 就順帶刪去了;沒準是條鏈,因此可以 while 一路刪上去。

用 prufer 還原一棵樹維護序列中節點的待加邊,當兒子連完、待加邊歸 000,就連向序列中下一個節點——似乎完全就是求 prufer 的相反操作,具體看下面的代碼。

P6086 【模板】Prufer 序列

思路

如上所述。

代碼

#include<bits/stdc++.h>
using namespace std;
#define ll long long
const ll N=1e5+9;
ll n,m,mod,k;
ll fa[N],siz[N];
ll fz(ll x)
{while(x!=fa[x])x=fa[x]=fa[fa[x]];return x;
}
void join(ll u,ll v)
{ll fu=fz(u),fv=fz(v);if(fu==fv)return;fa[fu]=fv;siz[fv]+=siz[fu];k--;
}
ll qpow(ll x,ll k)
{ll ret=1;while(k){if(k&1)ret=ret*x%mod;x=x*x%mod;k>>=1;}return ret;
}
int main()
{scanf("%lld%lld%lld",&n,&m,&mod);if(mod==1){puts("0");return 0;}k=n;for(int i=1;i<=n;i++)fa[i]=i,siz[i]=1;for(int i=1;i<=m;i++){ll u,v;scanf("%lld%lld",&u,&v);join(u,v);}if(k==1){puts("1");return 0;}ll ans=1;for(int i=1;i<=n;i++)if(i==fz(i))ans=ans*siz[i]%mod;ans=ans*qpow(n,k-2)%mod;printf("%lld",ans);return 0;
}

prufer 序列怎么求其實應用不廣,關鍵是其本身所帶有的性質更為重要。

應用

  • 把一個樹化為 prufer 序列,是建立 nnn 個節點無根樹和 n?2n-2n?2 個元素的序列的雙射。

  • 一個節點在 prufer 序列中出現次數為其度數減 111

  • Cayley 公式:對 nnn 個節點建立一棵無根樹,有 nn?2n^{n-2}nn?2 種方案。

    證明:任意一個長度為 n?2n-2n?2 的值域 [1,n][1,n][1,n] 的整數序列都可以通過 prufer 序列雙射對應一個生成樹,于是方案數就是 nn?2n^{n-2}nn?2

CF156D Clues

題意

給定一個 nnn 個點 mmm 條邊的帶標號無向圖,若其有 kkk 個連通塊,想要添加 k?1k-1k?1 條邊使得整個圖連通。求方案數。

1≤n≤1051\le n\le 10^51n1050≤m≤1050\le m\le 10^50m1051≤k≤1091\le k\le 10^91k109

思路

這是一道經典問題。

設每個連通塊有 sis_isi? 個節點,did_idi? 為連通塊的度數—— prufer 序列就是用度數所推。

在這里插入圖片描述
在這里插入圖片描述
計算上式即可。代碼略。

洛谷 P2290 HNOI2004 樹的計數

題意

一個有 nnn 個節點的樹,設它的節點分別為 v1,v2,…,vnv_1,v_2,\ldots,v_nv1?,v2?,,vn?,已知第 iii 個節點 viv_ivi? 的度數為 did_idi?,問滿足這樣的條件的不同的樹有多少棵。

1≤n≤1501\le n\le 1501n150,保證滿足條件的樹不超過 101710^{17}1017 個。

思路

其實方案數就是上一篇題解所提,(n?2d1?1,d2?1,d3?1,......,dn?1)=(n?2)!∏i=1n(di?1)!\dbinom{n-2}{d_1-1,d_2-1,d_3-1,......,d_n-1}=\dfrac{(n-2)!}{\displaystyle\prod_{i=1}^n(d_i-1)!}(d1??1,d2??1,d3??1,......,dn??1n?2?)=i=1n?(di??1)!(n?2)!?

好像會爆 long long,階乘的增長速度超乎想象,倒不如用它的普通組合數意義形式。設 si=di?1s_i=d_i-1si?=di??1sum=n?2sum=n-2sum=n?2(理論上是 ∑si\sum s_isi?,如果不是就不合法)。答案就是 ∏i=1n(sum?∑j=1i?1sjsi)\prod_{i=1}^n\binom{sum-\displaystyle\sum_{j=1}^{i-1}s_j}{s_i}i=1n?(si?sum?j=1i?1?sj??)

代碼略。

洛谷 P2624 HNOI2008 明明的煩惱

題意

給出標號為 111nnn 的點,以及某些點最終的度數,允許在任意兩點間連線,可產生多少棵度數滿足要求的樹?無解就輸出 ?1-1?1

1≤n≤10001\le n\le10001n1000

思路

這是上一題的加強版。

對于已知的 mmm 個點,我們可以直接套用上面的 (m?2d1?1,d2?1,d3?1,......,dm?1)=(m?2)!∏i=1m(di?1)!\dbinom{m-2}{d_1-1,d_2-1,d_3-1,......,d_m-1}=\dfrac{(m-2)!}{\displaystyle\prod_{i=1}^m(d_i-1)!}(d1??1,d2??1,d3??1,......,dm??1m?2?)=i=1m?(di??1)!(m?2)!? 公式,prufer 序列上已經選了的方案數為 (n?2∑i=1m(di?1))\dbinom{n-2}{\displaystyle\sum_{i=1}^m(d_i-1)}(i=1m?(di??1)n?2?),最后再把剩下的 n?mn-mn?m 個點,塞進 n?2?∑i=1m(di?1)n-2-\displaystyle\sum_{i=1}^m(d_i-1)n?2?i=1m?(di??1) 去:
(n?2∑i=1m(di?1))(m?2)!∏i=1m(di?1)!×(n?m)n?2?∑i=1m(di?1)\dbinom{n-2}{\displaystyle\sum_{i=1}^m(d_i-1)}\dfrac{(m-2)!}{\displaystyle\prod_{i=1}^m(d_i-1)!}\times(n-m)^{n-2-\displaystyle\sum_{i=1}^m(d_i-1)}(i=1m?(di??1)n?2?)i=1m?(di??1)!(m?2)!?×(n?m)n?2?i=1m?(di??1)

沒得化回普通組合數,要用高精捏。代碼略,有緣再寫。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/web/89351.shtml
繁體地址,請注明出處:http://hk.pswp.cn/web/89351.shtml
英文地址,請注明出處:http://en.pswp.cn/web/89351.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

學習OpenCV---顯示圖片

學習OpenCV—顯示圖片 最近在學習OpenCV入門&#xff0c;于是記錄一下自己的學習過程。 一、配置環境 第一步 從官方網站中下載OpenCV開源庫。官方下載網站 打開官網后&#xff0c;能看到有很多的版本。我個人下載的是4.11.0版本。點擊圖中的下載 下載完成后&#xff0c;解…

第一次接觸自動化監測,需要付費廠家安裝服務嗎?比人工測量主要區別是啥?

人工檢測是依靠目測檢查或借助于便攜式儀器測量得到的信息&#xff0c;但是隨著整個行業的發展&#xff0c;傳統的人工檢測方法已經不能滿足檢測需求&#xff0c;從人工檢測到自動化監測已是必然趨勢。 a. 從檢測方式看 人工檢測需要耗費大量的精力&#xff0c;從擺放檢測工具到…

VMware Workstation Pro 17下載安裝

注冊賬號 進入下載地址&#xff1a;Free Downloads - Support Portal - Broadcom support portal - https://support.broadcom.com/ 會讓注冊賬號&#xff0c;注冊一個就行 在右上角 下載 地址&#xff1a;Free Downloads - Support Portal - Broadcom support portal - ht…

SpringBoot 3.x集成阿里云OSS:文件上傳 斷點續傳 權限控制

SpringBoot 3.x集成阿里云OSS&#xff1a;文件上傳&#xff0f;斷點續傳&#xff0f;權限控制Spring Boot 3.x 集成阿里云 OSS 終極指南一、環境準備與依賴配置1. 添加阿里云 OSS SDK 依賴2. 配置 OSS 連接參數二、基礎文件上傳服務1. OSS 客戶端配置2. 文件上傳服務三、斷點續…

牛客周賽 Round 100

A小紅的雙排列沒什么好說的 直接 1 1 2 2 3 3 4 4……#define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include<iostream> #include<bits/stdc.h> #define ll long long using namespace std; int n; int main(){ios::sync_with_stdio(false); …

【Dv3Admin】菜單管理集成阿里巴巴自定義矢量圖標庫

圖標選擇是后臺管理系統中高頻功能。相比用 Element UI、Ant Design 等自帶的 icon 集&#xff0c;阿里巴巴 iconfont.cn 支持上傳和管理自定義圖標&#xff0c;并生成矢量字體&#xff0c;便于統一維護和擴展。 本文目標是支持自定義 iconfont 圖標的展示和選擇&#xff0c;并…

NO.7數據結構樹|線索二叉樹|樹森林二叉樹轉化|樹森林遍歷|并查集|二叉排序樹|平衡二叉樹|哈夫曼樹|哈夫曼編碼

線索二叉樹 線索二叉樹的基本概念 為了解決無法直接找到該結點在某種遍歷序列中的前驅和后繼結點的問題&#xff0c; 出現了線索二叉樹。 一個二叉樹通過如下的方法“穿起來” &#xff1a; 所有原本為空的右(孩子)指針改為指向該節點在某種遍歷序列中的后繼&#xff0c; 所有原…

R語言基礎| 基本圖形繪制(條形圖、堆積圖、分組圖、填充條形圖、均值條形圖)

目錄 一、前言 二、條形圖 1. 簡單的條形圖 2.堆積、分組和填充條形圖(柱狀圖) &#xff08;1&#xff09;堆積圖&#xff0c;對Improved進行堆積&#xff0c;注意position“stack” &#xff08;2&#xff09;分組圖&#xff0c;對Improved進行分組&#xff0c;注意posit…

SegNet:一種用于圖像分割的深度卷積編碼器解碼器架構

教程/講解視頻點擊文末名片1、什么是語義分割&#xff0c;什么是FCN 我們提出了一種新穎且實用的深度全卷積神經網絡架構&#xff0c;用于語義像素級分割&#xff0c;命名為SegNet。 語義分割是指為圖像中的每個像素分配一個類別標簽&#xff08;如道路、天空、汽車&#xff09…

PyTorch 數據加載全攻略:從自定義數據集到模型訓練

目錄 一、為什么需要數據加載器&#xff1f; 二、自定義 Dataset 類 1. 核心方法解析 2. 代碼實現 三、快速上手&#xff1a;TensorDataset 1. 代碼示例 2. 適用場景 四、DataLoader&#xff1a;批量加載數據的利器 1. 核心參數說明 2. 代碼示例 五、實戰&#xff1…

Python--plist文件的讀取

Python練習&#xff1a;讀取Apple Plist文件 Plist文件簡介 ??定義??&#xff1a;Apple公司創建的基于XML結構的文件格式??特點??&#xff1a;采用XML語法組織數據&#xff0c;可存儲鍵值對、數組等結構化信息文件擴展名??&#xff1a;.plist應用場景: ??iOS系統:?…

JAVA幾個注解記錄

在Java中&#xff0c;Data、AllArgsConstructor和NoArgsConstructor是Lombok庫提供的注解&#xff0c;用于自動生成Java類中的樣板代碼&#xff08;如getter、setter、構造函數等&#xff09;&#xff0c;從而減少冗余代碼&#xff0c;提高開發效率。以下是它們的詳細功能和使用…

js對象簡介、內置對象

對象、內置對象 jarringslee 對象 對象&#xff08;object&#xff09;是js的一種引用數據類型&#xff0c;是一種無序的數據集合“ul”&#xff08;類比于數組&#xff0c;有序的數據集合“ol”&#xff09;。 基本上等于結構體。 對象的聲明 //基本方法 let 對象名 {聲…

【工程篇】07:如何打包conda環境并拷貝到另一臺服務器上

這是一份以名為 qwen2.5-vl 的 Conda 環境為例的詳細操作手冊&#xff0c;指導您如何將其打包并遷移至另一臺服務器。操作手冊&#xff1a;遷移 Conda 環境 qwen2.5-vl 至新服務器 本文檔將提供兩種有效的方法來遷移您的 qwen2.5-vl 環境。請根據您的具體需求和服務器條件選擇最…

rustdesk遠控電腦替代todesk,平替向日葵等軟件

rustdesk網頁端遠控電腦docker run --restart always \ --privileged \ -p 9000:9000 \ -p 21114:21114 \ -p 21115:21115 \ -p 21116:21116 \ -p 21116:21116/udp \ -p 21117:21117 \ -p 21118:21118 \ -p 21119:21119 \ -e KEYj8muHpzr2HK00zm9D94b1UFkaJ1bEiWsyA1qxb1nOA \ …

板凳-------Mysql cookbook學習 (十二--------1)

第9章 存儲例程&#xff0c;觸發器和計劃事件 326 9.0 概述 326 9.1 創建復合語句對象 329 mysql> -- 恢復默認分隔符 mysql> DELIMITER ; mysql>mysql> DROP FUNCTION IF EXISTS avg_mail_size; Query OK, 0 rows affected (0.02 sec)mysql> DELIMITER $$ mysq…

密碼學系列文(3)--分組密碼

一、分組密碼概述分組密碼是許多系統安全的一個重要組成部分&#xff0c;可用于構造&#xff1a;擬隨機數生成器流密碼消息認證碼(MAC)和雜湊函數消息認證技術、數據完整性機構、實體認證協議以及單鑰數字簽字體制的核心組成部分應用中對于分組密碼的要求&#xff1a;安全性運行…

WCDB soci 查詢語句

測試代碼 #pragma once #include <string> #include <vector>// Assume OperationLog is a struct representing a row in the table struct OperationLog {int id;std::string op_type;std::string op_subtype;std::string details;std::string timestamp; };clas…

lesson16:Python函數的認識

目錄 一、為什么需要函數&#xff1f; 1. 拒絕重復造輪子 2. 讓代碼像句子一樣可讀 3. 隔離變化&#xff0c;降低維護成本 二、函數的定義&#xff1a;編寫高質量函數的5個要素 基本語法框架 1. 函數命名的黃金法則&#xff08;PEP8規范&#xff09; 2. 不可或缺的文檔…

通過輪詢方式使用LoRa DTU有什么缺點?

在物聯網系統中&#xff0c;DTU&#xff08;Data Transfer Unit&#xff09;通常用于通過485或M-Bus等接口抄讀子設備的數據&#xff0c;并將這些數據傳輸到平臺側。然而&#xff0c;如果DTU采用輪詢方式與平臺通信&#xff0c;會帶來一系列問題&#xff0c;尤其是在功耗和系統…