ALIGN

Pe lângă marea lui pasiune pentru informatică, lui Andino îi place să se joace cu fişierele. El deschide la întâmplare fişiere text şi se întreabă dacă poate alinia textul la stânga sau la dreapta. Cu toate că el este la curent cu tot ce se întâmplă în domeniul informaticii, el utilizează un editor de text primitiv care nu are funcţii de aliniere, aşa că vă roagă pe voi să-l ajutaţi.

Cerinţă

Să se alinieze un text dat la stânga sau la dreapta.

Date de intrare

Fişierul de intrare align.in conţine pe prima linie numărul n, numărul de linii din fişierul text şi un caracter x. Dacă x este 'S', atunci textul se va alinia la stânga, iar dacă x este 'D', se va alinia la dreapta. Pe următoarele n linii se citeşte textul din fişierul lui Andino.

Date de ieşire

Fişierul de ieşire align.out va conţine pe n linii textul aliniat.

Restricţii şi precizări

  • 1 ≤ n ≤ 100
  • lungimea unei linii nu va depăşi 200
  • dacă îl veţi ajuta pe Andino, veţi primi 100 de puncte şi probabil îl veţi convinge pe Andino să folosească un alt editor de texte

Exemplu

align.in

4 D
lui Andino ii place
mult informatica si doreste
sa mearga la olimpiada
pentru a-si dovedi calitatile de mare informatician

align.out

                                lui Andino ii place
                        mult informatica si doreste
                             sa mearga la olimpiada
pentru a-si dovedi calitatile de mare informatician

Explicaţie

Textul lui Andino a fost aliniat la dreapta.

Un alt exemplu

align.in

4 S
        lui Andino ii place
     mult informatica si doreste
           sa mearga la olimpiada
               pentru a-si dovedi calitatile de mare informatician

align.out

lui Andino ii place
mult informatica si doreste
sa mearga la olimpiada
pentru a-si dovedi calitatile de mare informatician

Explicaţie

Textul lui Andino a fost aliniat la stânga.

SOLUTIE

#include <fstream>
#include <cstring>
using namespace std;

char c[205];
string v[105];
int main()
{
      ifstream cin("align.in");
      ofstream cout("align.out");
    int n,lun,maxlun=0,ok;
    char dir;
    string s="";
    cin>>n>>dir;
    cin.get();
    for(int i=0; i<n; i++)
    {
        cin.getline(c,205);
        lun=strlen(c);
        if(dir=='S')
        {
              s="";ok=0;
              for(int j=0;j<lun;j++)
              {
                    if(c[j]!=' ')ok=1;
                    if(ok==1)s+=c[j];
              }
              cout<<s<<'\n';
        }
        else
        {
            s="";
            for(int j=0; j<lun; j++)
            {
                s+=c[j];
            }
            v[i]=s;
            maxlun=max(lun,maxlun);
        }
    }
    if(dir=='D')
    {
          for(int i=0;i<n;i++)
          {
                for(int j=0;j<maxlun-v[i].size();j++)cout<<" ";
                cout<<v[i]<<'\n';
          }
    }
    return 0;
}
%d bloggers like this: