👤

Se dă un număr natural x și un șir de numere naturale. Să se determine ultimul număr din șir care îl care ca sufix pe x.
Date de intrare

Fișierul de intrare nrsufix.in conține pe prima linie numărul x, iar pe următoarele linii numerele din șir.
Date de ieșire

Fișierul de ieșire nrsufix.out va conține pe prima linie ultimul număr din șir care îl care ca sufix pe x. Dacă în șir nu există nici un astfel de număr, se va afișa nu exista.
Restricții și precizări

toate numerele din fișierul de intrare au cel puțin una și cel mult nouă cifre
șirul dat va conține cel puțin două și cel mult 1.000.000 de elemente


Exemplu

nrsufix.in

12
3445 89312 1245 12 67120 312 1234578

nrsufix.out

312

Problema este de pe pbinfo(nr 803), iar codul trebuie sa fie in C++ sau in C.



Răspuns :

#include <fstream>
#include <vector>

using namespace std;

ifstream cin("nrsufix.in");
ofstream cout("nrsufix.out");

vector <string> words(string s)
{
    vector <string> a;
    string x;
    s+=' ';
    for (int i=0; i<s.size(); i++)
    {
        if (s[i]!=' ') x+=s[i];
        if (s[i]==' ' && x!="")
        {
            a.push_back(x);
            x="";
        }
    }
    return a;
}

bool suf(string x, string s)
{
    if (x.size()>s.size()) return false;
    s=s.substr(s.size()-x.size());
    return x==s;
}

int main()
{
    string a,s;
    vector <string> w;
    getline(cin,a);
    getline(cin,s);
    w=words(s);
    int x=-1;
    for (int i=w.size()-1; i>=0 && x==-1; i--)
        if (suf(a,w[i])) x=i;
    if (x==-1) cout << "nu exista";
    else cout << w[x];
    return 0;
}
Salut! Ti-am facut o sursa C++ si fara vectori dinamici. Succes!
#include <cstdio>
using namespace std;
int x,xx,a,nr,i,p;
bool ok;
int main()
{
    freopen("nrsufix.in","r",stdin);
    freopen("nrsufix.out","w",stdout);
    scanf("%d",&x);
    xx=x;
    p=1;
    while(xx)
    {
        p=p*10;
        xx=xx/10;
    }
    while(scanf("%d ",&a)!=EOF)
    {
        if(a%p==x) ok=true, nr=a;
    }
    if(ok) printf("%d\n",nr);
      else printf("nu exista");
    return 0;
}