《演算法競賽高階指南》0x03差分

2022-05-20 11:17:44 字數 1121 閱讀 8232

給定乙個序列,只能對乙個區間加一或者減一,問至少需要多少步使得所有數都變成一致的?有多少種一致序列?

利用差分,對乙個區間進行加一或者減一的話,一定是乙個差分+1加上另乙個差分-1。

**如下:

#includeusing

namespace

std;

typedef unsigned

intui;

typedef

long

long

ll;typedef unsigned

long

long

ull;

#define pf printf

#define mem(a,b) memset(a,b,sizeof(a))

#define prime1 1e9+7

#define prime2 1e9+9

#define pi 3.14159265

#define lson l,mid,rt<<1

#define rson mid+1,r,rt<<1|1

#define scand(x) scanf("%llf",&x)

#define f(i,a,b) for(int i=a;i<=b;i++)

#define scan(a) scanf("%d",&a)

#define mp(a,b) make_pair((a),(b))

#define p pair#define dbg(args) cout<<#args<<":"<#define inf 0x7ffffffinline

intread()

while(isdigit(ch))ans=(ans<<3)+(ans<<1)+ch-'

0',ch=getchar();

return ans*w;

}int

n,m,t;

const

int maxn=1e5+10

;const ll mod=10000

;ll a[maxn],d[maxn];

intmain()

//min(p,q)+abs(p,q)=max(p,q)

cout<"\n"

<1

;}

演算法競賽高階指南 0x00

快速冪模板,寫一下快速冪的原理。我們知道,乙個數 n 在二進位制 也可以是其他進製 下可以被表示為 a 1 a 2 2 1 a 3 2 2 a m 2 那麼我們可以考慮將其分拆成二進位制狀態下的每一位,然後做冪運算。這樣做的時間複雜度為 o log 2 n 實現的過程類似於倒過來的分治 當然也可以直...

《演算法競賽高階指南》0x32約數

求解 1,n 之間的最大的反素數,有性質 這個反素數是質因數個數最多的數中最小的乙個。證明 假設有乙個數質因數個數比它多,如果在他前面,不滿足反素數的定義,如果在他後面,一定可以找到第乙個質因數比它大的數,這個數作為結果更好,反證可知,這個數質因數一定是最多的 反證 假設有質因數與他的個數一樣但是比...

演算法競賽高階指南 0x11 棧 Editor

通過觀察我們可以將這個序列通過2個棧和2個陣列來維護5種操作進而達到題解,為了方便,直接用陣列來模擬棧 stkl n 游標左邊的棧 stkr n 游標右邊的棧 tl 左棧指標 tr 右棧指標 s n 字首和陣列 f n 最大字首和 對於第乙個操作,在游標處插入x,就是給stkl 的棧頂插入乙個x,字...