{"id":43,"date":"2009-11-26T20:26:00","date_gmt":"2009-11-26T12:26:00","guid":{"rendered":"http:\/\/localhost\/?p=43"},"modified":"2009-11-26T20:26:00","modified_gmt":"2009-11-26T12:26:00","slug":"usaco_2005_november_silver","status":"publish","type":"post","link":"https:\/\/www.shuizilong.com\/wjmzbmr\/?p=43","title":{"rendered":"USACO 2005 November Silver"},"content":{"rendered":"<p> <a href=\"http:\/\/acm.pku.edu.cn\/JudgeOnline\/searchproblem?field=source&amp;key=USACO+2005+November+Silver\">http:\/\/acm.pku.edu.cn\/JudgeOnline\/problem?id=3044<\/a><br \/>http:\/\/acm.pku.edu.cn\/JudgeOnline\/problem?id=3045<br \/>http:\/\/acm.pku.edu.cn\/JudgeOnline\/problem?id=3046<br \/>@@@1@@@<br \/>\u8003\u8651\u4e00\u5757\u623f\u5b50(\u5c31\u662f\u4e24\u8fb9\u90fd\u662f\u5730\u3002\u3002)<br \/>\u90a3\u4e48\u5176\u4e2d\u6700\u77ee\u7684\u4e00\u5757\u7684\u9ad8\u5ea6\u5fc5\u7136\u662f\u8fd9\u4e00\u5757\u4e2d\u6700\u77ee\u7684\u3002\u3002<br \/>\u90a3\u4e48\u8d2a\u5fc3\u7684\u9009\u62e9\u81ea\u7136\u662f\u8ba9\u5b83\u53d8\u5f97\u6700\u5bbd\u3002\u3002\u7136\u540e\u518d\u5f80\u4e0a\u642d\u3002\u3002\u3002<br \/>\u6211\u76f4\u63a5\u66b4\u529b\u5b9e\u73b0\u4e86\u3002\u3002\u5e73\u5747\u662fO(nlogn)\u3002\u3002\u6700\u574f\u662f\uff2f(n^2)\u3002\u3002\u5e78\u597d\u6570\u636e\u5f88\u539a\u9053\u3002\u3002<br \/>\u66b4\u529b\u627e\u6700\u5c0f\u503c\u3002\u3002<br \/>\u5b98\u65b9\u7a0b\u5e8f\u53ea\u8981\u6808\u626b\u63cf\u5c31\uff2f\uff2b\u4e86\u3002\u3002\u6211\uff33\uff22\u963f\u3002\u3002<br \/>#include&lt;iostream&gt;<br \/>#include&lt;cstdio&gt;<br \/>using namespace std;<br \/>const int maxy=500000,maxn=50000;<br \/>int w,n;<br \/>int H[maxn];<br \/>int cal(int i,int j)<br \/>{<br \/> if(i&gt;j) return 0;<br \/> if(i==j) return H[i]&gt;0;<br \/> int c=maxy;<br \/> for(int o=i;o&lt;=j;o++)<br \/>  c=min(H[o],c);<br \/> int a=i,ans=0;<br \/> for(int o=i;o&lt;=j;o++)<br \/>  if(H[o]==c)<br \/>   ans+=cal(a,o-1),a=o+1;<br \/> ans+=cal(a,j);<br \/> if(c) ans++;<br \/> return ans;<br \/>}<br \/>int main()<br \/>{ <br \/> cin&gt;&gt;n&gt;&gt;w;int x;<br \/> for(int i=0;i&lt;n;i++)<br \/> {<br \/>  scanf(&quot;%d %d&quot;,&amp;x,H+i);<br \/> }<br \/> cout&lt;&lt;cal(0,n-1)&lt;&lt;endl;<br \/>}@@@@2@@@@<br \/>\u770b\u4e24\u4e2a\u725bi\u548ci&#8217;\u3002\u3002\u8bbe\u4ed6\u4eec\u91cd\u91cf\u548c\u529b\u91cf\u5206\u522b\u4e3aA,B,A&#8217;,B&#8217;..<br \/>\u4ed6\u4eec\u4e0a\u9762\u7684\u725b\u603b\u91cd\u4e3a\uff33<br \/>\u5047\u5982A+B&gt;A&#8217;+B&#8217;\u3000\u90a3\u4e48\u3000A-B&#8217;&gt;A&#8217;-B<br \/>\uff33<br \/>\uff21\u3000\uff22<br \/>\uff21\u2018\u3000\uff22\u2019<br \/>max(S-B,S+A-B&#8217;) i\u5728\u4e0a\u9762\u3002\u3002<br \/>max(S-B&#8217;,S+A&#8217;-B) i&#8217;\u5728\u4e0a\u9762\u3002\u3002<br \/>\u90a3\u4e48\u603b\u662fi&#8217;\u5728\u4e0a\u9762\u66f4\u597d\u3002\u3002\u3002<br \/>\u540c\u7406\u5982\u679cA+B=A&#8217;+B&#8217;\u3002\u3002<br \/>\u90a3\u4e48\uff22\u5927\u7684\u5728\u4e0a\u9762\u597d\u3002\u3002\u3002<br \/>\u76f4\u63a5\u6392\u5e8f\u5c31OK\u4e86\u3002\u3002<br \/>#include&lt;iostream&gt;<br \/>#include&lt;cstdio&gt;<br \/>#include&lt;algorithm&gt;<br \/>using namespace std;<br \/>const int maxn=50000,inf=~0U&gt;&gt;1;<br \/>int n;<br \/>struct node<br \/>{<br \/> int w,s;<br \/> bool operator&lt;(const node&amp;x) const<br \/> {<br \/>  int a=w+s,b=x.w+x.s;<br \/>  if(a!=b) return a&lt;b;<br \/>  return w&lt;x.w;<br \/> }<br \/>}Q[maxn];<br \/>int main()<br \/>{<br \/> cin&gt;&gt;n;<br \/> for(int i=0;i&lt;n;i++)<br \/> {<br \/>  scanf(&quot;%d %d&quot;,&amp;Q[i].w,&amp;Q[i].s);<br \/> }<br \/> sort(Q,Q+n);<br \/> int Sum=0,ans=-inf;<br \/> for(int i=0;i&lt;n;i++)<br \/> {<br \/>  ans=max(ans,Sum-Q[i].s);<br \/>  Sum+=Q[i].w;<br \/> }<br \/> cout&lt;&lt;ans&lt;&lt;endl;<br \/>}@@@@3@@@@<br \/>\u8fd9\u9053\u9898\u8ba9\u6211\u60f3\u5230\u4e86\u6bcd\u51fd\u6570\u3002\u3002<br \/>\u7136\u540e\u6211\u5c31\u76f4\u63a5\u4e0a\u6bcd\u51fd\u6570\u4e86\u3002\u3002\u3002<br \/>#include&lt;iostream&gt;<br \/>using namespace std;<br \/>const int maxn=1000,maxl=100000,Mod=1000000;<br \/>struct P<br \/>{<br \/> int *C;<br \/> int n;<br \/> P(int n):n(n)<br \/> {<br \/>  C=new int[n+1];  <br \/>  for(int i=0;i&lt;=n;i++)<br \/>   C[i]=1;<br \/> }<br \/> int&amp; operator[](int v){return C[v];} <br \/> void operator*=(P&amp;x)<br \/> {<br \/>  int*now=new int[n+x.n+1];<br \/>  for(int i=0;i&lt;=n+x.n;i++) now[i]=0;<br \/>  for(int i=0;i&lt;=n;i++)<br \/>   for(int j=0;j&lt;=x.n;j++)<br \/>   {<br \/>    now[i+j]+=C[i]*x[j];<br \/>    now[i+j]%=Mod;<br \/>   }<br \/>  delete[] C;<br \/>  C=now;n+=x.n;<br \/> }<br \/>};<br \/>int C[maxn]={0};<br \/>int T,A,S,B;<br \/>int main()<br \/>{<br \/> cin&gt;&gt;T&gt;&gt;A&gt;&gt;S&gt;&gt;B; <br \/> while(A&#8211;)<br \/> {<br \/>  int t;cin&gt;&gt;t;<br \/>  C[t-1]++;<br \/> }<br \/> P ans(0);<br \/> for(int i=0;i&lt;T;i++)<br \/> {<br \/>  P now(C[i]);<br \/>  ans*=now;<br \/> }<br \/> int sum=0;<br \/> for(int i=S;i&lt;=B;i++)<br \/>  sum+=ans[i],sum%=Mod;<br \/> cout&lt;&lt;sum&lt;&lt;endl;<br \/>} <\/p>\n","protected":false},"excerpt":{"rendered":"<p>http:\/\/acm.pku.edu.cn\/JudgeOnline\/problem?id=3044http:\/\/acm.pku.edu.cn\/JudgeOnline\/problem?id=3045http:\/\/acm.pku.edu.cn\/JudgeOnline\/problem?id=3046@@@1@@@\u8003\u8651\u4e00\u5757\u623f\u5b50(\u5c31\u662f\u4e24\u8fb9\u90fd\u662f\u5730\u3002\u3002)\u90a3\u4e48\u5176\u4e2d\u6700\u77ee\u7684\u4e00\u5757\u7684\u9ad8\u5ea6\u5fc5\u7136\u662f\u8fd9\u4e00\u5757\u4e2d\u6700\u77ee\u7684\u3002\u3002\u90a3\u4e48\u8d2a\u5fc3\u7684\u9009\u62e9\u81ea\u7136\u662f\u8ba9\u5b83\u53d8\u5f97\u6700\u5bbd\u3002\u3002\u7136\u540e\u518d\u5f80\u4e0a\u642d\u3002\u3002\u3002\u6211\u76f4\u63a5\u66b4\u529b\u5b9e\u73b0\u4e86\u3002\u3002\u5e73\u5747\u662fO(nlogn)\u3002\u3002\u6700\u574f\u662f\uff2f(n^2)\u3002\u3002\u5e78\u597d\u6570\u636e\u5f88\u539a\u9053\u3002\u3002\u66b4\u529b\u627e\u6700\u5c0f\u503c\u3002\u3002\u5b98\u65b9\u7a0b\u5e8f\u53ea\u8981\u6808\u626b\u63cf\u5c31\uff2f\uff2b\u4e86\u3002\u3002\u6211\uff33\uff22\u963f\u3002\u3002#include&lt;iostream&gt;#include&lt;cstdio&gt;using namespace std;const int maxy=500000,maxn=50000;int w,n;int H[maxn];int cal(int i,int j){ if(i&gt;j) return 0; if(i==j) return H[i]&gt;0; int c=maxy; for(int o=i;o&lt;=j;o++) c=min(H[o],c); int a=i,ans=0; for(int o=i;o&lt;=j;o++) if(H[o]==c) ans+=cal(a,o-1),a=o+1; ans+=cal(a,j); if(c) ans++; return ans;}int main(){ cin&gt;&gt;n&gt;&gt;w;int x; for(int i=0;i&lt;n;i++) { scanf(&quot;%d %d&quot;,&amp;x,H+i); } cout&lt;&lt;cal(0,n-1)&lt;&lt;endl;}@@@@2@@@@\u770b\u4e24\u4e2a\u725bi\u548ci&#8217;\u3002\u3002\u8bbe\u4ed6\u4eec\u91cd\u91cf\u548c\u529b\u91cf\u5206\u522b\u4e3aA,B,A&#8217;,B&#8217;..\u4ed6\u4eec\u4e0a\u9762\u7684\u725b\u603b\u91cd\u4e3a\uff33\u5047\u5982A+B&gt;A&#8217;+B&#8217;\u3000\u90a3\u4e48\u3000A-B&#8217;&gt;A&#8217;-B\uff33\uff21\u3000\uff22\uff21\u2018\u3000\uff22\u2019max(S-B,S+A-B&#8217;) i\u5728\u4e0a\u9762\u3002\u3002max(S-B&#8217;,S+A&#8217;-B) i&#8217;\u5728\u4e0a\u9762\u3002\u3002\u90a3\u4e48\u603b\u662fi&#8217;\u5728\u4e0a\u9762\u66f4\u597d\u3002\u3002\u3002\u540c\u7406\u5982\u679cA+B=A&#8217;+B&#8217;\u3002\u3002\u90a3\u4e48\uff22\u5927\u7684\u5728\u4e0a\u9762\u597d\u3002\u3002\u3002\u76f4\u63a5\u6392\u5e8f\u5c31OK\u4e86\u3002\u3002#include&lt;iostream&gt;#include&lt;cstdio&gt;#include&lt;algorithm&gt;using namespace std;const int maxn=50000,inf=~0U&gt;&gt;1;int n;struct node{ int w,s; bool operator&lt;(const node&amp;x) [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":[],"categories":[10],"tags":[],"jetpack_featured_media_url":"","_links":{"self":[{"href":"https:\/\/www.shuizilong.com\/wjmzbmr\/index.php?rest_route=\/wp\/v2\/posts\/43"}],"collection":[{"href":"https:\/\/www.shuizilong.com\/wjmzbmr\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.shuizilong.com\/wjmzbmr\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.shuizilong.com\/wjmzbmr\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.shuizilong.com\/wjmzbmr\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=43"}],"version-history":[{"count":0,"href":"https:\/\/www.shuizilong.com\/wjmzbmr\/index.php?rest_route=\/wp\/v2\/posts\/43\/revisions"}],"wp:attachment":[{"href":"https:\/\/www.shuizilong.com\/wjmzbmr\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=43"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.shuizilong.com\/wjmzbmr\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=43"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.shuizilong.com\/wjmzbmr\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=43"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}