-
Notifications
You must be signed in to change notification settings - Fork 163
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Suffix Array #243
Open
Ankitr19
wants to merge
6
commits into
codeIIEST:master
Choose a base branch
from
Ankitr19:master
base: master
Could not load branches
Branch not found: {{ refName }}
Loading
Could not load tags
Nothing to show
Loading
Are you sure you want to change the base?
Some commits from the old base branch may be removed from the timeline,
and old review comments may become outdated.
Open
Suffix Array #243
Changes from all commits
Commits
Show all changes
6 commits
Select commit
Hold shift + click to select a range
1eb6038
Suffix Array
Ankitr19 dd3b439
Update Suffix_Array.cpp
Ankitr19 5c4fe0d
Update Suffix_Array.cpp
Ankitr19 b8f7184
Update Suffix_Array.cpp
Ankitr19 d96682d
Update Suffix_Array.cpp
Ankitr19 e376f12
Update Suffix_Array.cpp
Ankitr19 File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
28 changes: 28 additions & 0 deletions
28
Competitive Coding/Strings/String Search/SuffixArray/Suffix_Array.cpp
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,28 @@ | ||
#include<bits/stdc++.h> | ||
using namespace std; | ||
|
||
void Suff_Arr(string s) | ||
{ | ||
map<string,int> m; | ||
|
||
vector<string> v; | ||
for(int i = 0; i < s.size();i++) | ||
{ | ||
m[s.substr(i,s.size()-i)] = i; | ||
v.push_back(s.substr(i,s.size()-i)); | ||
} | ||
sort(v.begin(),v.end()); | ||
for(int i = 0; i < v.size();i++) | ||
{ | ||
cout << m[v[i]] <<" "; | ||
} | ||
cout<<"\n"; | ||
} | ||
|
||
int main() | ||
{ | ||
string s; | ||
cin >> s; | ||
Suff_Arr(s); | ||
return 0; | ||
} |
27 changes: 27 additions & 0 deletions
27
Competitive Coding/Strings/String Search/SuffixArray/Suffix_Array.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,27 @@ | ||
This is the code to build suffix array for any given string input. | ||
|
||
Suffix Array:- | ||
A suffix array for a given string is basically a sorted array of all suffixes of a string. | ||
|
||
For example:- | ||
|
||
Given the string is "banana" | ||
|
||
The suffixes are:- | ||
|
||
0 banana 5 a | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. make this part more look good. Like codify this part to make it look good. Otherwise this part looks odd |
||
1 anana sorted 3 ana | ||
2 nana --------------> 1 anana | ||
3 ana alpabetically 0 banana | ||
4 na 4 na | ||
5 a 2 nana | ||
|
||
So, the suffix array for the string "banana" will be [5,3,1,0,4,2] | ||
|
||
Application of suffix array:- | ||
|
||
Suffix array is an extremely useful data structure, it can be used for a wide range of problems. Following are some famous problems where Suffix array can be used. | ||
1) Pattern Searching | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. use * instead of numbering |
||
2) Finding the longest repeated substring | ||
3) Finding the longest common substring | ||
4) Finding the longest palindrome in a string |
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
some comments here will make it better