Advertisement
sidjha57

Increasing Sequences

Jul 19th, 2021
136
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 3.56 KB | None | 0 0
  1. //template
  2.  
  3. #include<bits/stdc++.h>
  4. //#include<ext/pb_ds/assoc_container.hpp>
  5. //#include<ext/pb_ds/tree_policy.hpp>
  6. //#include <ext/pb_ds/trie_policy.hpp>
  7. //using namespace __gnu_pbds;
  8. using namespace std;
  9. //typedef tree<ll, null_type, less<ll>, rb_tree_tag, tree_order_statistics_node_update> pbds;
  10. //typedef trie<string,null_type,trie_string_access_traits<>,pat_trie_tag,trie_prefix_search_node_update> pbtrie;
  11.  
  12. #define ll                       long long int
  13. #define ld                       long double
  14. #define mod                      1000000007
  15. #define inf                      1e18
  16. #define endl                     "\n"
  17. #define pb                       push_back
  18. #define vi                       vector<ll>
  19. #define vs                       vector<string>
  20. #define pii                      pair<ll,ll>
  21. #define ump                      unordered_map
  22. #define mp                       make_pair
  23. #define pq_max                   priority_queue<ll>
  24. #define pq_min                   priority_queue<ll,vi,greater<ll> >
  25. #define all(n)                   n.begin(),n.end()
  26. #define ff                       first
  27. #define ss                       second
  28. #define mid(l,r)                 (l+(r-l)/2)
  29. #define bitc(n)                  __builtin_popcount(n)
  30. #define SET(a)                   memset( a, -1, sizeof a )
  31. #define CLR(a)                   memset( a,  0, sizeof a )
  32. #define Pi                       3.141592653589793
  33. #define loop(i,a,b)              for(int i=(a);i<=(b);i++)
  34. #define looprev(i,a,b)           for(int i=(a);i>=(b);i--)
  35. #define _fast                    ios_base::sync_with_stdio(0);  cin.tie(0);
  36. #define iter(container,it)       for(__typeof(container.begin()) it = container.begin(); it != container.end(); it++)
  37. #define log(args...)             {string _s = #args; replace(_s.begin(), _s.end(), ',', ' '); stringstream _ss(_s); istream_iterator<string> _it(_ss); err(_it, args); }
  38. #define logarr(arr,a,b)          for(int z=(a);z<=(b);z++) cout<<(arr[z])<<" ";cout<<endl;
  39. template <typename T> T          gcd(T a, T b){if(a%b) return gcd(b,a%b);return b;}
  40. template <typename T> T          lcm(T a, T b){return (a*(b/gcd(a,b)));}
  41. vs tokenizer(string str,char ch) {std::istringstream var((str)); vs v; string t; while(getline((var), t, (ch))) {v.pb(t);} return v;}
  42.  
  43. void err(istream_iterator<string> it) {}
  44. template<typename T, typename... Args>
  45. void err(istream_iterator<string> it, T a, Args... args) {
  46. cout << *it << " = " << a << endl;
  47. err(++it, args...);
  48. }
  49.  
  50. void solve() {
  51.     int n,k,L; string s; cin >> n >> s;
  52.     ll dp[n+1][n+1],mx[n+1][n+1];
  53.     CLR(dp),CLR(mx);
  54.  
  55.     // finding max length string which matches
  56.     looprev(i,n-1,0) {
  57.         looprev (j,n-1,0) {
  58.             if (s[i] != s[j]) mx[i][j] = 0;
  59.             else
  60.                 mx[i][j] = 1 + mx[i+1][j+1];
  61.         }
  62.     }
  63.  
  64.     //base case
  65.     loop (i,0,n) {
  66.          dp[0][i] = 1;
  67.          dp[i][0] = 1;
  68.     }
  69.    //creating the actual dp
  70.     loop (j,1,n) {
  71.         loop (i,1,n) {
  72.             k = 1;
  73.             while (j > k) {
  74.                 dp[i][j] = (dp[i][j] + dp[i-j][k])%mod;
  75.                 k++;
  76.             }
  77.             L = mx[i-2*j+1][i-j+1];
  78.             if (i < 1 || (i-2*j+L+1 < 0) || (i-j+L+1 < 0) || (i-j < 0)) continue;
  79.             if (L < j && s[i-2*j+L+1] < s[i-j+L+1])
  80.                 dp[i][j] = (dp[i][j] + dp[i-j][j])%mod;
  81.         }
  82.     }
  83.  
  84.  
  85.     ll ans = 0;
  86.     loop (j,1,n) ans = (ans + dp[n][j])%mod;
  87.    
  88.     cout << ans << "\n";
  89. }
  90.  
  91. int main(int argc, char const *argv[]){
  92.     _fast
  93.     ll t=1;
  94.     while(t--){
  95.      solve();
  96.     }
  97.   return 0;
  98. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement