【BZOJ 3238】[AHOI2013] 差异

题目传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=3238
离线版题目:http://paste.ubuntu.com/18084975/
数据生成器:http://paste.ubuntu.com/16074559/

这个东西,想了想,不会做QAQ于是可耻地看题解,果断SA算贡献
最近在做专题,又看到这个题,发现SAM算贡献不是更好算吗QAQ
贴一个SA的代码吧!SAM就偷懒不写啦!o( ̄▽ ̄)ブ

#include<iostream>
#include<cstdio>
#include<cstring>
#define LL long long
#define SA Suffix_Array
using namespace std;

const int MAXN = 1000000+9;

namespace Suffix_Array{
	int sa[MAXN],bot[MAXN],t1[MAXN],t2[MAXN],height[MAXN],*rank,*tmp;
	int n,m;
	
	inline void build(char *s){
		n = strlen(s+1); m = 26;
		rank = t1; tmp = t2;
		
		for (int i=1;i<=n;i++) bot[tmp[i]=s[i]-'a'+1]++;
		for (int i=2;i<=m;i++) bot[i] += bot[i-1];
		for (int i=1;i<=n;i++) sa[bot[tmp[i]]--] = i;
		rank[sa[1]] = m = 1;
		for (int i=2;i<=n;i++) rank[sa[i]] = s[sa[i]]==s[sa[i-1]]?m:++m;
		
		for (int k=1;k<=n;k*=2){
			int tot = 0; 
			for (int i=1;i<=m;i++) bot[i] = 0;
			for (int i=n-k+1;i<=n;i++) tmp[++tot] = i;
			for (int i=1;i<=n;i++) if (sa[i] > k) tmp[++tot] = sa[i] - k;
			for (int i=1;i<=n;i++) bot[rank[i]]++;
			for (int i=2;i<=m;i++) bot[i] += bot[i-1];
			for (int i=n;i;i--) sa[bot[rank[tmp[i]]]--] = tmp[i];
			
			swap(rank, tmp); rank[sa[1]] = m = 1;
			for (int i=2;i<=n;i++) if (tmp[sa[i]] == tmp[sa[i-1]] && tmp[sa[i]+k] == tmp[sa[i-1]+k]) rank[sa[i]] = m; else rank[sa[i]] = ++m; if (m >= n) break;
		}
	}
	
	inline void GetHeight(char *s){
		for (int i=1;i<=n;i++) if (rank[i] > 1) {
			int sta = max(0, height[rank[i-1]]-2);
			int p1 = i+sta, p2 = sa[rank[i]-1]+sta;
			while (s[p1++] == s[p2++]) sta++;
			height[rank[i]] = sta;
		}
	}
};

int L[MAXN],R[MAXN]; LL vout;
int cnt,que[MAXN],pos[MAXN]; 

inline void GetAns(){
	using namespace Suffix_Array;
	for(int i=1;i<=n;i++) vout += (LL)i*(LL)(n-1);
	
	cnt = 0;
	for (int i=1;i<=n;i++){ while (cnt && que[cnt] >= height[i]) cnt--;
		L[i] = pos[cnt]+1;
		que[++cnt] = height[i]; pos[cnt] = i;
	} 
	
	cnt = 0; pos[0] = n+1;
	for (int i=n;i;i--){
		while (cnt && que[cnt] > height[i]) cnt--;
		R[i] = pos[cnt]-1;
		que[++cnt] = height[i]; pos[cnt] = i;
	} 
	
	for (int i=1;i<=n;i++) vout -= 2LL*(LL)(i-L[i]+1)*(LL)(R[i]-i+1)*(LL)height[i];
	printf("%lld",vout);
}

char pat[MAXN];
int main(){
	scanf("%s",pat+1);
	SA::build(pat);
	SA::GetHeight(pat); 
	GetAns(); 
	return 0;
}

86 thoughts to “【BZOJ 3238】[AHOI2013] 差异”

  1. Good day! This is kind of off topic but I need some help from an established blog.
    Is it tough to set up your own blog? I’m not very techincal but
    I can figure things out pretty quick. I’m thinking about setting up my own but I’m not sure where to start.
    Do you have any points or suggestions? Thanks

  2. I’m impressed, I have to admit. Seldom do I come across a blog that’s both educative and amusing, and without a doubt, you have hit the nail on the head.
    The issue is something which too few folks are speaking intelligently about.
    I am very happy that I came across this in my search for something
    relating to this.

  3. My coder is trying to persuade me to move to .net from PHP.
    I have always disliked the idea because of the costs.
    But he’s tryiong none the less. I’ve been using WordPress
    on a number of websites for about a year and am nervous about
    switching to another platform. I have heard good things about blogengine.net.
    Is there a way I can import all my wordpress content into it?

    Any help would be really appreciated!

  4. Hi there, i read your blog occasionally and i own a similar one and i was just curious if
    you get a lot of spam responses? If so how do you protect against it, any plugin or anything you can advise?
    I get so much lately it’s driving me crazy so any help is very much appreciated.

  5. What’s Happening i’m new to this, I stumbled upon this I’ve discovered It absolutely
    helpful and it has aided me out loads. I hope to give a
    contribution & aid different customers like its aided me.

    Good job.

  6. Greetings from Ohio! I’m bored to tears at work so I decided to check out your site on my iphone during
    lunch break. I love the info you present here and can’t wait to take a
    look when I get home. I’m surprised at how fast your blog loaded on my phone ..

    I’m not even using WIFI, just 3G .. Anyways, amazing site!

  7. Excellent beat ! I wish to apprentice whilst you amend your site, how could
    i subscribe for a blog site? The account aided me a acceptable deal.
    I were tiny bit familiar of this your broadcast provided brilliant transparent concept natalielise plenty of fish

  8. Wonderful blog! Do you have any tips for
    aspiring writers? I’m hoping to start my own blog soon but I’m a little lost on everything.
    Would you propose starting with a free platform like WordPress or go for a paid option? There are so many
    options out there that I’m completely overwhelmed ..

    Any tips? Bless you!

  9. Hi! Someone in my Myspace group shared this site with
    us so I came to take a look. I’m definitely enjoying the information. I’m bookmarking and will be tweeting this to my
    followers! Great blog and terrific design and style.

  10. Thank you for any other informative website. The place else may just I get that kind of
    info written in such an ideal method? I have a undertaking that I am just now working on, and I’ve been at the
    glance out for such information.

  11. Its such as you learn my thoughts! You appear to
    know a lot about this, like you wrote the e book in it or
    something. I believe that you could do with
    some p.c. to drive the message house a little bit, however
    instead of that, this is fantastic blog. An excellent read.
    I will definitely be back.

  12. Hello there I am so happy I found your blog, I really found
    you by accident, while I was browsing on Aol for something else,
    Anyways I am here now and would just like to say many
    thanks for a marvelous post and a all round entertaining blog (I also love
    the theme/design), I don’t have time to read it all at the minute but I have saved
    it and also included your RSS feeds, so when I have time
    I will be back to read more, Please do keep up the great job.

  13. Write more, thats all I have to say. Literally, it seems as
    though you relied on the video to make your point.
    You clearly know what youre talking about, why throw away your intelligence on just posting videos to your weblog when you could be giving us something enlightening to
    read?

  14. This is the right web site for anyone who wishes to find out about this topic.

    You understand a whole lot its almost hard to argue with you (not that I personally would want to…HaHa).
    You certainly put a new spin on a subject that has been written about for a long time.
    Great stuff, just great!

  15. Great blog you have here but I was wondering if you knew of
    any message boards that cover the same topics talked about here?
    I’d really like to be a part of group where I can get feed-back from other knowledgeable individuals that share the same interest.
    If you have any recommendations, please let me know.
    Thanks a lot!

  16. Hey! Do you know if they make any plugins to help with Search Engine Optimization?
    I’m trying to get my blog to rank for some targeted keywords but
    I’m not seeing very good gains. If you know of any
    please share. Appreciate it!

  17. Just wish to say your article is as astonishing. The clarity in your post is just excellent and i can assume you are an expert on this
    subject. Well with your permission let me to grab your feed to keep updated
    with forthcoming post. Thanks a million and please continue the
    gratifying work.

  18. It is the best time to make a few plans for the future and it’s
    time to be happy. I have read this post and if I may I want to counsel
    you some interesting things or advice. Maybe you can write next articles referring to
    this article. I want to read more issues about it!

  19. This is the right blog for everyone who hopes to find out about this topic.
    You understand a whole lot its almost hard to argue with
    you (not that I actually will need to…HaHa). You definitely put a brand new
    spin on a subject that’s been written about for decades.
    Excellent stuff, just wonderful!

  20. Hola! I’ve been following your weblog for
    a while now and finally got the courage to go ahead and give you a shout out from
    Humble Tx! Just wanted to tell you keep up the great job!

  21. I’ve been exploring for a little for any high-quality articles or weblog posts in this sort of space .
    Exploring in Yahoo I at last stumbled upon this site.
    Studying this information So i’m satisfied to convey that I’ve a very excellent uncanny feeling I came upon exactly what I needed.

    I so much surely will make certain to don?t forget
    this website and provides it a glance regularly.

  22. Nice blog here! Also your web site loads up very fast! What host are you using?
    Can I get your affiliate link to your host?
    I wish my site loaded up as quickly as yours lol

  23. What i don’t realize is in reality how you are not actually a lot more neatly-liked than you might be
    right now. You’re very intelligent. You recognize thus significantly in the case of this subject,
    made me in my view consider it from numerous varied angles.
    Its like women and men are not fascinated except it’s one thing to accomplish with Lady gaga!
    Your own stuffs nice. All the time take care of it up!

  24. My spouse and I stumbled over here coming from a different web page and thought
    I might as well check things out. I like what I see so i am
    just following you. Look forward to looking into your
    web page yet again.

  25. I was excited to discover this web site. I want to to thank
    you for ones time for this wonderful read!!
    I definitely enjoyed every bit of it and i also
    have you book-marked to see new things in your blog.

  26. Fantastic website you have here but I was wanting to know if you knew of any message boards
    that cover the same topics discussed in this article?
    I’d really love to be a part of community where I can get responses from other knowledgeable people
    that share the same interest. If you have any recommendations, please
    let me know. Appreciate it!

  27. I must thank you for the efforts you have put in writing
    this blog. I am hoping to see the same high-grade
    content by you in the future as well. In truth, your creative writing
    abilities has motivated me to get my very own site now 😉

  28. I do not even know how I ended up here, but I thought this post was
    great. I do not know who you are but certainly you are going to a famous blogger
    if you aren’t already 😉 Cheers!

  29. I do consider all the ideas you have introduced
    for your post. They are really convincing and will definitely work.
    Nonetheless, the posts are too quick for beginners.
    Could you please prolong them a little from next time?
    Thanks for the post.

  30. Hello I am so glad I found your weblog, I really found
    you by accident, while I was looking on Yahoo for something else,
    Regardless I am here now and would just like to say kudos for a marvelous post and a all round entertaining
    blog (I also love the theme/design), I don’t have time to look over it all at the moment but I
    have saved it and also added in your RSS feeds,
    so when I have time I will be back to read more, Please do
    keep up the great job.

  31. Hello! I understand this is sort of off-topic however I needed to
    ask. Does building a well-established website such as yours require a large amount
    of work? I’m brand new to writing a blog but I do write in my diary everyday.
    I’d like to start a blog so I can easily share my
    experience and thoughts online. Please let me know if you have any kind of ideas or tips for brand new aspiring blog owners.

    Appreciate it!

  32. Hello! I’ve been reading your website for a long time now and finally
    got the courage to go ahead and give you a shout out from Porter
    Texas! Just wanted to mention keep up the great work!

  33. I’ve been exploring for a little for any high quality articles or blog posts in this kind
    of space . Exploring in Yahoo I ultimately stumbled upon this website.
    Reading this information So i am happy to exhibit that I have a very good uncanny feeling I came upon exactly what
    I needed. I so much without a doubt will make sure to don?t forget
    this site and give it a look on a relentless basis.

  34. An interesting discussion is definitely worth comment.
    There’s no doubt that that you should publish more on this subject matter, it may not be a taboo
    subject but usually people don’t speak about such issues.
    To the next! Cheers!!

  35. I am not sure where you are getting your info, but great
    topic. I needs to spend some time learning more or understanding more.

    Thanks for fantastic info I was looking for this information for
    my mission.

  36. Exceptional post but I was wanting to know if you could write a litte more on this topic?
    I’d be very grateful if you could elaborate a
    little bit more. Thanks!

  37. This is really interesting, You are a very skilled blogger.
    I have joined your feed and look forward to seeking more of your magnificent post.
    Also, I have shared your website in my social networks!

  38. Hi there! I could have sworn I’ve been to
    this blog before but after checking through some of the post I realized it’s new to me.
    Anyhow, I’m definitely glad I found it and I’ll be book-marking and checking back frequently!

  39. Oh my goodness! Awesome article dude! Thank you, However I am going through troubles with your RSS.
    I don’t know why I cannot join it. Is there anybody having similar RSS problems?
    Anyone that knows the answer can you kindly respond?
    Thanks!!

  40. Whats up this is kinda of off topic but I was wanting
    to know if blogs use WYSIWYG editors or if you have to manually code with HTML.
    I’m starting a blog soon but have no coding experience so I wanted to get advice from someone with experience.
    Any help would be enormously appreciated!

  41. That is a great tip particularly to those fresh to the blogosphere.
    Brief but very accurate info… Many thanks for sharing this one.
    A must read post!

  42. It is perfect time to make some plans for the future and it is time to be happy.
    I have read this post and if I could I wish to suggest you few interesting things or tips.
    Perhaps you can write next articles referring to this article.

    I desire to read more things about it!

  43. I like the helpful information you provide in your articles. I will bookmark your weblog and check again here frequently. I’m quite certain I’ll learn many new stuff right here! Best of luck for the next!

Leave a Reply

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