SUBST1 - New Distinct Substrings


Given a string, we need to find the total number of its distinct substrings.

Input

T- number of test cases. T<=20; Each test case consists of one string, whose length is <= 50000

Output

For each test case output one number saying the number of distinct substrings.

Example

Input:
2
CCCCC
ABABA

Output:
5
9

hide comments
seyedssz: 2017-08-24 14:04:32

0.02 s with O(n*log^2)

tnorris: 2017-07-01 02:49:24

Naive Solution is O(n^2 * logn) - hits time limit
Doubling Solution is O(n * log^2 n) - hits time limit (might not in a faster language)
There are faster solutions in O(n * logn) and O(n). According to comments here, thats the time threshold for this problem.

Last edit: 2017-07-04 00:57:03
jaijoshi: 2017-04-29 21:39:52

I am using n*logn*logn solution with array of structure for buiding suffix array and still getting TLE. and for lcp i am using kasai's algo. Please help me.
Taking help from : https://discuss.codechef.com/questions/21385/a-tutorial-on-suffix-arrays

sultania23: 2017-03-26 12:05:39

n*logn*logn AC

sultania23: 2017-03-26 12:04:59

2 days to figure out by taking little help..nice problem

deerishi: 2016-07-16 00:24:06

Why does O(nlogn) (suffix array using radix sort) time out ?

Last edit: 2016-07-16 00:24:19
ravi: 2016-03-22 16:36:41

nlognlogn =tle nlogn=ac better to learn nlogn found this useful
http://stackoverflow.com/questions/34402080/suffix-array-construction-on-logn-competitive-programming-3-steven-halim
take care case CCCCC with sentinel character

Last edit: 2016-03-22 16:37:50
Dhawal Harkawat: 2016-01-20 17:07:32

Optimized nlog^2n gets passed in 0.12s, while nlogn passes in 0.14s. I dont know why??

humanity: 2015-12-30 22:43:11

nlogn(used radix sort everytime) with pointer optimisation got accepted though 0.27 seconds :( ,any ideas for better implementation

Last edit: 2015-12-30 22:43:54
Divyansh Shukla: 2015-12-23 10:47:00

For java, use the O(n) version. It got AC in 0.15s


Added by:Hoang Hong Quan
Date:2006-01-18
Time limit:0.280s
Source limit:50000B
Memory limit:1536MB
Cluster: Cube (Intel G860)
Languages:All except: NODEJS PERL6 VB.NET
Resource:Base on a problem in ByteCode06