四校聯訓 騎行川藏 二分

2021-08-09 02:31:49 字數 919 閱讀 1861

鏈結

一、提議描述。

給定乙個無向圖,邊存在邊權;

給定起點終點,求一條路徑;

將路徑上任意邊的邊權減去一些數,這些數權值和<=k;

設f為修改後路徑上的最大邊權;

要求最小化f。

對於m=n-1,路徑唯一,貪心修改路徑上邊權最大值即可。

對於k=0,求最小生成樹,則答案為樹上路徑的邊權最大值。

正解:此問題直接求解不好做,可轉化為判定性問題。

二分答案,判斷答案可行性。

時間複雜度n^2*log_n。

#include

#include

#include

#define r register

#define max_n 50010

using namespace std;

struct ededge[max_n<<1];

int n,m,et,kk;

int st[max_n],dis[max_n];

int vis[max_n],q[30000010],h,t;

intread()

bool check(int bound)}}

if(dis[n]<=kk)return true;

else

return false;

}int main()

,st[x]=et++;

edge[et]=(ed),st[y]=et++;

}l=0,r=max_n;

while(r>l)

printf("%d",r);

return

0;}

NOI2012 騎行川藏 求導 二分

乙個能看的題解!預備知識只有高中數學的 導數 不用什麼偏導數 拉格朗日乘子法之類的我看不懂的東西 如果你不知道什麼是導數,可以找本高中數學選修2 2來看一下!看第一章第1 2節就好啦。傳送門 選修2 2 感性理解一下這道題 一開始,我們可以給所有路段隨便分配乙個速度。接下來,我們需要在一些路段上耗費...

寧波多校(四) C石頭劃分(二分)

看到最小最大,顯然是經典二分 因此只需要列舉最大距離進行check 如果能存在k組或以上能滿足組間距離大於等於mid 那麼就可以放大,否則縮小 include include include include include include include using namespace std ty...

2015 去哪兒校招 二分查詢

對於乙個有序陣列,我們通常採用二分查詢的方式來定位某一元素,請編寫二分查詢的演算法,在陣列中查詢指定元素。給定乙個整數陣列a及它的大小n,同時給定要查詢的元素val,請返回它在陣列中的位置 從0開始 若不存在該元素,返回 1。若該元素出現多次,請返回第一次出現的位置。測試樣例 1,3,5,7,9 5...