【BZOJ 2815】[ZJOI2012] 灾难

题目传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=2815
题面传送门:http://blog.csdn.net/flaze_/article/details/51334708

这题好好玩!
让我们来膜拜fanhq666:
http://fanhq666.blog.163.com/blog/static/8194342620124274154996/

这题把数学模型抽象出来就是:
给一个有向无环图,问每个节点删掉之后会导致多少个点不可达。
感觉还是挺有用的样子!

#include<bits/stdc++.h>
#define LL long long
using namespace std;

const int N = 100000;
const int M = 1000000;

int head[N],to[M],nxt[M],fa[N][18];
int in[N],sz[N],dep[N],n; 
vector<int> G[N];

inline int read(){
	char c=getchar(); int ret=0,f=1;
	while (c<'0'||c>'9') {if(c=='-')f=-1;c=getchar();}
	while (c<='9'&&c>='0') {ret=ret*10+c-'0';c=getchar();}
	return ret*f;
}

inline void Add_Edge(int u, int v) {
	static int T = 0; in[v]++;
	to[++T] = v; nxt[T] = head[u]; head[u] = T;
}

inline int lca(int x, int y) {
	if (dep[x] < dep[y]) swap(x,y);
	for (int i=17;~i;i--) {
		if (dep[fa[x][i]] >= dep[y]) {
			x = fa[x][i];
		}
	}
	if (x == y) return y;
	for (int i=17;~i;i--) {
		if (fa[x][i] != fa[y][i]) {
			x = fa[x][i];
			y = fa[y][i];
		}
	}
	return fa[x][0];
}

void solve(int w) {
	dep[w] = dep[fa[w][0]] + 1;
	if (w) G[fa[w][0]].push_back(w);
	for (int i=1;i<=17;i++) {
		fa[w][i] = fa[fa[w][i-1]][i-1];
	}
	
	for (int i=head[w];i;i=nxt[i]) {
		if (fa[to[i]][0] == -1) {
			fa[to[i]][0] = w;
		} else {
			fa[to[i]][0] = lca(fa[to[i]][0],w);
		}
		
		if (--in[to[i]] == 0) {
			solve(to[i]);
		}
	}
}

void Get_Size(int w) {
	sz[w] = 1;
	for (int i=G[w].size()-1;~i;i--) {
		Get_Size(G[w][i]);
		sz[w] += sz[G[w][i]];
	}
}

int main(){
	memset(fa,-1,sizeof(fa));
	n = read();
	for (int i=1;i<=n;i++) {
		for (int j=read();j;j=read()) {
			Add_Edge(j,i);
		}
		if (!in[i]) {
			Add_Edge(0,i);
		}
	}
	
	fa[0][0] = 0;
	solve(0);
	Get_Size(0);
	
	for (int i=1;i<=n;i++) {
		printf("%d\n",sz[i] - 1);
	}
	return 0;
}

217 thoughts to “【BZOJ 2815】[ZJOI2012] 灾难”

  1. Hello! I’m at work surfing around your blog from my new apple iphone!
    Just wanted to say I love reading your blog and look forward to all
    your posts! Carry on the outstanding work!

  2. I am not sure where you’re getting your info,
    but great topic. I needs to spend some time learning much
    more or understanding more. Thanks for magnificent information I was
    looking for this info for my mission.

  3. Hello there I am so grateful I found your blog, I really found
    you by mistake, while I was browsing on Bing for something else, Anyways I am
    here now and would just like to say thanks for a tremendous post and a all round entertaining blog (I also love
    the theme/design), I don’t have time to go through it all
    at the moment but I have book-marked it and also added in your RSS feeds, so
    when I have time I will be back to read a lot more, Please do keep up the awesome work.

  4. Hi there just wanted to give you a quick heads up and
    let you know a few of the pictures aren’t loading properly.
    I’m not sure why but I think its a linking issue. I’ve tried
    it in two different internet browsers and both show the same results.

  5. Greetings! I know this is somewhat off topic but I was wondering which blog
    platform are you using for this site? I’m getting sick and
    tired of WordPress because I’ve had issues with hackers and I’m looking at options for another platform.
    I would be great if you could point me in the direction of a good platform.

  6. Hmm it seems like your website ate my first comment (it was super long) so I guess I’ll just sum it up what
    I submitted and say, I’m thoroughly enjoying your blog. I too am an aspiring blog
    writer but I’m still new to the whole thing.

    Do you have any points for novice blog writers? I’d genuinely appreciate it.

  7. Your way of explaining the whole thing in this piece of writing
    is truly good, every one be able to simply be aware of it, Thanks a
    lot. plenty of fish natalielise

  8. It’s nearly impossible to find experienced people in this particular topic, but you seem like you know what you’re talking
    about! Thanks natalielise plenty of fish

  9. great put up, very informative. I’m wondering why the opposite specialists of this sector don’t realize this.

    You must proceed your writing. I am confident, you have a huge readers’ base already!

  10. Thanks on your marvelous posting! I definitely enjoyed reading
    it, you are a great author. I will remember to bookmark your
    blog and definitely will come back very soon. I want to encourage you
    to definitely continue your great job, have a nice holiday weekend!

  11. An impressive share! I’ve just forwarded this onto a friend who had been conducting a
    little research on this. And he actually bought me lunch because I found it
    for him… lol. So allow me to reword this….
    Thank YOU for the meal!! But yeah, thanx for spending the time to discuss this subject here on your web page.

  12. Howdy are using WordPress for your site platform? I’m new to the
    blog world but I’m trying to get started and create my own. Do you require any
    coding expertise to make your own blog? Any help would
    be greatly appreciated!

  13. Hi there! I know this is kinda off topic nevertheless I’d figured I’d ask.
    Would you be interested in exchanging links or maybe guest writing a blog
    article or vice-versa? My website addresses a lot of the same subjects as yours and I feel we
    could greatly benefit from each other. If you might be interested feel free to shoot me an email.

    I look forward to hearing from you! Great blog by the way!

  14. Greetings from Los angeles! I’m bored to tears at work so I decided
    to check out your site on my iphone during lunch break.
    I enjoy the info you provide here and can’t wait to take a look when I get home.

    I’m amazed at how quick your blog loaded on my phone ..
    I’m not even using WIFI, just 3G .. Anyhow, excellent site!

  15. Hello, i think that i saw you visited my web site thus i came to “return the favor”.I’m trying to find
    things to enhance my web site!I suppose its ok to use
    a few of your ideas!!

  16. Wow, incredible blog layout! How lengthy have you been running
    a blog for? you make blogging glance easy. The whole look of your web site is wonderful, as well as the
    content material!

  17. Hi! This is kind of off topic but I need some guidance from an established blog.
    Is it very hard to set up your own blog? I’m not very techincal but I can figure things out
    pretty fast. I’m thinking about making my own but I’m not
    sure where to start. Do you have any ideas or suggestions?

    Thanks

  18. Usually I don’t learn article on blogs, but I would like to say that this
    write-up very pressured me to check out and do it!

    Your writing taste has been surprised me. Thank you, quite
    great post.

  19. Hi, i believe that i saw you visited my blog thus i got here to return the want?.I’m attempting to
    to find issues to enhance my web site!I guess its
    ok to use some of your concepts!!

  20. “Hey! Would you mind if I share your blog with my facebook group? There’s a lot of folks that I think would really appreciate your content. Please let me know. Cheers”

  21. Great blog right here! Additionally your website lots up fast!
    What web host are you the use of? Can I am getting your affiliate
    link in your host? I want my web site loaded up as fast
    as yours lol

  22. What you said made a ton of sense. But, consider
    this, what if you composed a catchier title? I mean, I don’t want to tell you how
    to run your blog, but suppose you added a title that makes people want more?
    I mean 【BZOJ 2815】[ZJOI2012] 灾难 – Qizy's Database is a little vanilla.
    You might glance at Yahoo’s home page and see how they create news titles to get people to open the links.
    You might add a related video or a related pic or two to grab readers interested about what you’ve got to say.
    Just my opinion, it might make your website a little livelier.

  23. My spouse and I absolutely love your blog and
    find the majority of your post’s to be exactly I’m looking for.

    Do you offer guest writers to write content in your
    case? I wouldn’t mind writing a post or elaborating on a number of the subjects you write
    in relation to here. Again, awesome weblog!

  24. Thank you for the good writeup. It in fact was a
    amusement account it. Look advanced to far added agreeable
    from you! By the way, how can we communicate?

  25. Hi there. I discovered your site by the use of Google even as searching for a related topic, your site came up. It seems to be good. I’ve bookmarked it in my google bookmarks to visit then.

  26. Hiya, I am really glad I’ve found this information. Nowadays bloggers publish only about gossip and net stuff and this is really annoying. A good blog with interesting content, this is what I need. Thanks for making this web-site, and I will be visiting again. Do you do newsletters by email?

  27. I just wanted to jot down a brief remark in order to thank you for those lovely solutions you are giving out here. My long internet investigation has finally been rewarded with pleasant know-how to talk about with my co-workers. I ‘d state that that we readers actually are unquestionably fortunate to be in a very good place with so many wonderful professionals with very beneficial tips and hints. I feel very much happy to have come across your webpages and look forward to many more exciting times reading here. Thanks once again for a lot of things.

  28. [url=http://onlineviagra.us.com]viagra[/url][url=http://vardenafil.us.org]vardenafil hcl[/url][url=http://onlineviagra.us.com]onlineviagra.us.com[/url][url=http://1stantabusenow.com]disulfiram (antabuse) [/url][url=http://cephalexin500.us.org]what it cephalexin 500mg used for [/url][url=http://buyprednisolone.us.com]http://buyprednisolone.us.com[/url][url=http://rimonabant.team]rimonabant.team[/url]

  29. This particular blog is obviously entertaining and besides informative. I have discovered helluva interesting stuff out of this blog. I ad love to return over and over again. Thanks a bunch!

  30. international parcel, international shipping, Worldwide shipping from the UK, worldwide shipping company, ship large items, large parcel delivery, shipping from the uk, uk shipping solution, worldwide shipping, global shipping

  31. It is appropriate time to make some plans for the future and it’s timeto be happy. I have read this post and if I could I desireto suggest you some interesting things or advice.Perhaps you could write next articles referring to this article.I desire to read more things about it!

  32. I’d like to thank you for the efforts you’ve put in penning this
    site. I really hope to see the same high-grade content from you
    in the future as well. In fact, your creative writing abilities
    has motivated me to get my own website now 😉

  33. You’re so cool! I don’t think I’ve read anything like that before.

    So great to discover another person with a few genuine thoughts on this subject.
    Seriously.. many thanks for starting this up. This site is one thing that’s needed on the internet, someone with some originality!

  34. hello there and thank you to your info – I’ve definitely picked up anything new from proper here. I did alternatively experience a few technical points the usage of this site, since I experienced to reload the web site lots of occasions prior to I may just get it to load correctly. I have been pondering if your hosting is OK? Now not that I’m complaining, however sluggish loading instances instances will very frequently affect your placement in google and could harm your high-quality ranking if ads and ***********|advertising|advertising|advertising and *********** with Adwords. Anyway I’m including this RSS to my e-mail and can look out for a lot more of your respective exciting content. Make sure you replace this once more very soon..

  35. Hi there would you mind sharing which blog platform you’re using?
    I’m planning to start my own blog soon but I’m having a difficult time deciding
    between BlogEngine/Wordpress/B2evolution and Drupal.
    The reason I ask is because your design seems different
    then most blogs and I’m looking for something completely unique.
    P.S Sorry for being off-topic but I had to ask!

  36. It’s beautiful value enough for me. In my view, if all web owners and bloggers made good content as you probably did, the internet will likely be a lot more useful than ever before. It is perfect time to make some plans for the future and it’s time to be happy. I’ve read this post and if I could I want to suggest you few interesting things or suggestions. Perhaps you could write next articles referring to this article. I wish to read even more things about it! I have been browsing online greater than 3 hours nowadays, yet I by no means discovered any interesting article like yours. It’s pretty worth enough for me. Personally, if all web owners and bloggers made good content as you probably did, the web might be a lot more useful than ever before.

  37. Great beat ! I would like to apprentice while you amend
    your site, how could i subscribe for a blog site? The account helped me a
    acceptable deal. I had been a little bit acquainted
    of this your broadcast offered bright clear idea

  38. I do not even know how I finished up right here, but I thought this publish was once great.I do not recognize who you might be however certainly you’re goingto a famous blogger in case you are not already. Cheers!

  39. Hi there, You’ve done an incredible job. I will definitely digg it
    and personally recommend to my friends. I am sure they will be benefited from this web site.

  40. Hi there would you mind stating which blog platform you’re using?
    I’m planning to start my own blog in the near future but I’m having a hard time making a
    decision between BlogEngine/Wordpress/B2evolution and Drupal.

    The reason I ask is because your design seems different then most blogs and
    I’m looking for something unique. P.S Apologies for being
    off-topic but I had to ask!

  41. Good day! I could have sworn I’ve visited this site before but after browsing through many of the posts I realized it’s new
    to me. Nonetheless, I’m certainly pleased I found it and I’ll be book-marking it and checking
    back often!

  42. Hiya, I am really glad I have found this information. Today bloggers publish only about gossip and internet stuff and this is actually irritating. A good blog with interesting content, this is what I need. Thank you for making this website, and I will be visiting again. Do you do newsletters by email?

  43. Hi would you mind letting me know which webhost you’re utilizing?
    I’ve loaded your blog in 3 different browsers and I
    must say this blog loads a lot faster then most.
    Can you recommend a good internet hosting provider at a reasonable price?
    Thanks a lot, I appreciate it!

  44. I’m not sure exactly why but this website is loading incredibly slow for me.
    Is anyone else having this issue or is it a problem on my end?

    I’ll check back later and see if the problem still exists.

  45. Awesome write-up. I am a regular visitor of your site and appreciate you taking the time to maintain the excellent site. I will be a regular visitor for a long time.

  46. I blog frequently and I really thank you for your content.
    The article has truly peaked my interest. I will bookmark your blog and keep checking for new details about once
    a week. I subscribed to your Feed as well.

  47. Do you have a spam problem on this site; I also am a blogger,
    and I was wondering your situation; we have created some nice methods and we are looking to exchange strategies with others, be sure to shoot me an email if interested.

  48. Wonderful goods from you, man. I have understand your stuff previous
    to and you are just extremely excellent. I actually like what you have acquired here, really like what you’re stating and the way in which you say it.
    You make it enjoyable and you still care for to keep it sensible.
    I cant wait to read far more from you. This
    is really a great web site.

  49. I’m really enjoying the theme/design of your weblog. Do you ever run into any internet browser compatibility issues?
    A number of my blog visitors have complained about my website not working correctly in Explorer
    but looks great in Opera. Do you have any solutions to help fix this problem?

  50. I do not even know the way I finished up here, however I believed this submit used
    to be great. I don’t realize who you’re but certainly you are going to a famous
    blogger should you are not already. Cheers!

  51. Write more, thats all I have to say. Literally,
    it seems as though you relied on the video to make your point.
    You definitely know what youre talking about, why waste
    your intelligence on just posting videos to your site when you could
    be giving us something informative to read?

  52. Today, I went to the beachfront with my children.
    I found a sea shell and gave it to my 4 year old daughter and said “You can hear the ocean if you put this to your ear.” She placed the
    shell to her ear and screamed. There was a hermit crab inside and it pinched
    her ear. She never wants to go back! LoL I know this is entirely off topic but I had to tell someone!

  53. It is not my first time to pay a visit this
    web site, i am visiting this website dailly and get pleasant information from here every day.

  54. Awesome post. I am a normal visitor of your web site and appreciate you taking the time to maintain the excellent site. I will be a regular visitor for a really long time.

  55. I think this is one of the so much significant information for me.And i am happy studying your article. However wanna commentary on few general things,The site taste is wonderful, the articles is truly nice :D. Good process, cheers

  56. Thank you for the good writeup. It in reality was a enjoyment
    account it. Glance complex to far added agreeable from you!

    By the way, how can we communicate?

  57. This is the fitting blog for anybody who desires to find out about this topic. You notice a lot its nearly onerous to argue with you (not that I truly would want…HaHa). You undoubtedly put a brand new spin on a subject thats been written about for years. Nice stuff, simply great!

  58. What i do not understood is actually how you are no longer actually a lot more well-favored than you might be right now. You’re so intelligent. You recognize therefore significantly in terms of this matter, produced me for my part imagine it from numerous various angles. Its like men and women aren’t interested unless it is something to accomplish with Lady gaga! Your own stuffs outstanding. Always handle it up!

  59. Hello just wanted to give you a quick heads up. The text
    in your post seem to be running off the screen in Firefox.
    I’m not sure if this is a format issue or something to do with internet browser compatibility but I
    figured I’d post to let you know. The style and design look great though!
    Hope you get the problem fixed soon. Thanks

  60. I just could not depart your web site prior to suggesting that I actually enjoyed the usual information a person provide on your guests? Is going to be again steadily to investigate cross-check new posts.

  61. You’re so awesome! I do not think I’ve truly read through anything like that before.
    So great to discover another person with some original thoughts on this issue.
    Really.. many thanks for starting this up. This website is one thing that is
    required on the internet, someone with a little originality!

  62. Today, while I was at work, my cousin stole my iphone and tested to see if it can survive a 40 foot drop, just so she can be a youtube sensation. My iPad is now destroyed and she has 83 views. I know this is entirely off topic but I had to share it with someone!

  63. Hello There. I found your blog using msn. This is a really well written article. I will make sure to bookmark it and come back to read more of your useful information. Thanks for the post. I will certainly return.

  64. Hey there. I found your blog via Google whilst looking for a comparable matter, your web site got here up. It appears good. I’ve bookmarked it in my google bookmarks to come back then.

  65. I have been absent for a while, but now I remember why I used to love this site. Thank you, I’ll try and check back more often. How frequently you update your site?

  66. Wow! This could be one particular of the most useful blogs We ave ever arrive across on this subject. Basically Fantastic. I am also an expert in this topic so I can understand your hard work.

  67. Thanks for another wonderful article. The place else could anyone get thatkind of info in such a perfect method ofwriting? I’ve a presentation next week, and I am at the look for suchinformation.

  68. Howdy! Quick question that’s totally off topic. Do you know how to make your site mobile friendly? My site looks weird when viewing from my apple iphone. I’m trying to find a template or plugin that might be able to fix this issue. If you have any recommendations, please share. With thanks!

  69. Hiya, I’m really glad I have found this information. Today bloggers publish just about gossip and net stuff and this is really frustrating. A good blog with interesting content, this is what I need. Thanks for making this site, and I will be visiting again. Do you do newsletters by email?

  70. I’ve been surfing online more than three hours as of late, but I never discovered any interesting article like yours. It?¦s lovely value sufficient for me. In my view, if all web owners and bloggers made just right content material as you did, the net shall be much more helpful than ever before.

  71. Oh my goodness! Impressive article dude! Thanks, However I am encountering problems with your RSS. I don’t know the reason why I am unable to join it. Is there anybody else getting identical RSS issues? Anyone that knows the solution will you kindly respond? Thanks!!

  72. Youre so cool! I dont suppose Ive learn anything like this before. So nice to find anyone with some original ideas on this subject. realy thank you for starting this up. this web site is one thing that’s wanted on the web, someone with a little bit originality. helpful job for bringing something new to the internet!

  73. Hiya, I am really glad I’ve found this info. Nowadays bloggers publish just about gossip and internet stuff and this is actually frustrating. A good site with interesting content, this is what I need. Thank you for making this web-site, and I will be visiting again. Do you do newsletters by email?

  74. I have checked your website and i’ve found some duplicate content,that’s why you don’t rank high in google, but there is a tool that can help you to create100 unique content, search for; SSundee advices unlimited content for yourblog

Leave a Reply

Your email address will not be published. Required fields are marked *