Sereja and Two Strings 2

All submissions for this problem are available.
Read problems statements in Mandarin Chinese, Russian and Vietnamese as well.
Sereja has a string A consisting of n lower case English letters.
Sereja calls two strings X and Y each of length n similar if they can be made equal by applying the following operation at most once in each of them.
 Chose any two position i, j in the string (i can be equal to j too). Swap the characters at position i with character at position j.
For example strings "abcd" and "acbd" are similar, strings "ab" and "ab" are similar, but strings "abcde" and "bcdea" are not similar. Note that strings "abc" and "cab" are also similar, as you can swap 'a' and 'c' in the first string to get "cba" and 'a' and 'b' in the second string to get "cba".
Now Sereja is interested in finding number of ordered pairs of non similar strings X and Y such that they can be constructed from a given string A by permutation of its characters. As answer could be large, please output your answer modulo (10^{9} + 7).
Note A string s (of size n) is said to be constructed from string t (also of size n) by permutation of its characters if there exists a permutation P (of length n), such that s[i] = t[P[i]] for each i from 1 to n.
Input
 First line contain integer T  number of test cases.
 For each of the next T lines:
 Each line contains a string A as defined in the problem.
Output
For each test case, output answer modulo 1000000007 (10^{9} + 7) in separate line.Constraints
 1 ≤ T ≤ 10
 1 ≤ n ≤ 10^5
Constraints
 Subtask #1: 1 ≤ n ≤ 10 (25 points)
 Subtask #2: 1 ≤ n ≤ 100 (25 points)
 Subtask #3: 1 ≤ n ≤ 1000 (25 points)
 Subtask #4: original constraints (25 points)
Example
Input: 2 z abcd Output: 0 144
Author:  sereja 
Tester:  furko 
Editorial  http://discuss.codechef.com/problems/SEATSTR2 
Tags  combinatorics, march16, medium, sereja 
Date Added:  11102014 
Time Limit:  1 sec 
Source Limit:  50000 Bytes 
Languages:  C, CPP14, JAVA, PYTH, PYTH 3.6, CS2, PAS fpc, PAS gpc, RUBY, PHP, GO, NODEJS, HASK, SCALA, D, PERL, FORT, WSPC, ADA, CAML, ICK, BF, ASM, CLPS, PRLG, ICON, SCM qobi, PIKE, ST, NICE, LUA, BASH, NEM, LISP sbcl, LISP clisp, SCM guile, JS, ERL, TCL, PERL6, TEXT, CLOJ, FS 
Comments
 Please login at the top to post a comment.
SUCCESSFUL SUBMISSIONS
Fetching successful submissions