#include <iostream>
#include <vector>
#include <string>
#include <algorithm>
using namespace std;

int main() {
    string a;
    vector<string> suffixes;
    cin>>a;
    for(int i=0;i<a.size();i++){
        suffixes.push_back(a.substr(i));
    }
    sort(suffixes.begin(),suffixes.end());
    for(string b:suffixes){
        cout<<b<<endl;
    }
    return 0;
}