Informatică, întrebare adresată de curajosul33, 9 ani în urmă

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ăspunsuri la întrebare

Răspuns de lozanalex
1
#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;
}
Răspuns de express
1
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;
}


curajosul33: E C?
curajosul33: nu?
curajosul33: bravo
curajosul33: e perfecta
curajosul33: felicitari
Alte întrebări interesante