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
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;
}
#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
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;
}
#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?
Alte întrebări interesante
Matematică,
8 ani în urmă
Limba română,
8 ani în urmă
Chimie,
9 ani în urmă
Limba română,
9 ani în urmă
Limba română,
9 ani în urmă