[关闭]
@01010101 2018-10-18T16:26:58.000000Z 字数 1709 阅读 971

1018


T1水题,开始把j敲成了i,还好后来补发了大样例。

T2
大 M 定义:对于一个序列 v[1..n],当1<= x < y <=n 且 x,y 均为整数时,同样满足|v[x]-v[y] |<=K*|x-y|,则称 K 的最小整数值为序列 v 的 Lipschitz 常数。
现在给你一个长度为 n 的序列 v[1..n]并给出 q 个询问,对于每对询问[l,r],你需要求出 v[l..r] 的所有子序列 v[x..y](l<= x< y<= r)的 Lipschitz 常数之和。

骗分都挂了,MLE!!!!!!!!!!!!!!!!!!!,n<=100000,q<=100。

T3
大 M 是一只怪兽,准备到比特王国吃人。比特王国有 n 个城市,城市之间由 n1
条无向的路径连接,通过每条路径的时间为 1。其中有 m 个特别的城市,这 m 个
城市里都各有一个大神,于是大 M 打算不管普通人,只吃掉这些大神。然而大 M 是
一只具有特别能力的怪物,它可以一开始降临到 n 个城市中的任意一个城市,同时还
有一次机会在任意两个城市间打开一个虫洞,不消耗时间就能相互到达。
大 M 想知道它最少要花多少时间来吃掉这些大神(吃的时间忽略不计),如
果你不帮它它就会吃了你。
当然,大 M 是不属于这个时空的存在,所以在他吃完所有大神之后需要回到
最初降临的城市,通过时空门返回原来的位面。
m<=n<=123456

第二问对了,第一问挂了。后来TOM告诉我两者没有关系,那个点只有在虚树(大神树)上就可以了。第二问就是先dp,再找大神树的直径作为虫洞。

  1. void dfs1(int u,int fa){
  2. for(int i=head[u];i!=-1;i=e[i].nxt){
  3. int v=e[i].v;
  4. if(v!=fa){
  5. dfs1(v,u);
  6. if(in[v]){
  7. dp[u]+=dp[v]+2;
  8. in[u]+=in[v];
  9. }
  10. }
  11. }
  12. }
  13. void bfs(int s,int flg){
  14. memset(vis,0,sizeof(vis));
  15. q[++hd]=make_pair(s,0);
  16. while(hd>=tl){
  17. int u=q[hd].first;int d=q[hd].second;
  18. hd--;
  19. for(int i=head[u];i!=-1;i=e[i].nxt){
  20. if(!vis[e[i].v]){
  21. if(in[e[i].v]&&d+1>ans) {
  22. ans=d+1;
  23. pos=e[i].v;
  24. }
  25. vis[e[i].v]=1;
  26. q[++hd]=make_pair(e[i].v,d+1);
  27. }
  28. }
  29. }
  30. }
  31. struct node{
  32. int idx;
  33. char s[20];
  34. int len;
  35. bool operator < (const node &x) const{
  36. int l=min(len,x.len);
  37. for(int i=1;i<=l;++i)
  38. if(s[i]!=x.s[i]) return s[i]<x.s[i];
  39. return len<x.len;
  40. }
  41. }d[N];
  42. int a,b;
  43. char ss[20];
  44. int main(){
  45. freopen("superm.in","r",stdin);
  46. freopen("superm.out","w",stdout);
  47. memset(head,-1,sizeof(head));
  48. n=read();m=read();
  49. for(int i=1;i<n;++i){
  50. a=read();b=read();
  51. adde(a,b);adde(b,a);
  52. }
  53. for(int i=1;i<=m;++i){
  54. a=read();
  55. in[a]++;
  56. }
  57. if(m==1) {printf("%d\n%d\n",a,0);return 0;}
  58. dfs1(a,0);
  59. bfs(a,0);
  60. ans=0;bfs(pos,1);
  61. for(int i=1;i<=n;++i){
  62. if(in[i]){
  63. d[++cnt].idx=i;
  64. int t=i,j=0;
  65. while(t){
  66. ss[++j]=t%10+'0';
  67. t/=10;
  68. }
  69. for(int jj=j;jj>=1;--jj) d[cnt].s[jj]=ss[j-jj+1];
  70. d[cnt].len=j;
  71. }
  72. }
  73. sort(d+1,d+cnt+1);
  74. printf("%d\n%lld\n",d[1].idx,dp[a]-ans);
  75. return 0;
  76. }
添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注