AJUTORR
Cerinţa
Se consideră şirul definit mai jos:
în care nu există doi termeni cu aceeași paritate aflați pe poziții consecutive: 1, 2, 3, 4, 7, 8, 15, 16 .....
Pentru un număr natural x, termen al şirului dat, se cere să se afișeze pe ecran, în ordine strict descrescătoare, separați prin câte un spațiu, toţi termenii şirului care sunt mai mici sau egali cu x.
Date de intrare
Programul citeşte de la tastatură numărul x
Date de ieşire
Programul va afişa pe ecran în ordine strict descrescătoare, separați prin câte un spațiu, toţi termenii şirului care sunt mai mici sau egali cu x.
Restricţii şi precizări
1 ≤ x ≤ 1.000.000.000
Anexe:
Răspunsuri la întrebare
Răspuns de
4
#include <iostream>
using namespace std;
int function(unsigned n){
if(n==1)
return 1;
if(n%2)
return 1 + 2*function(n-2);
return 1 + function(n-1);
}
int main() {
unsigned x,i=1;
long v[61];
cin>>x;
while(function(i)<=x){
v[i] = function(i);
i++;
}
while(i>1){
cout<<v[--i]<<" ";
}
return 0;
}
using namespace std;
int function(unsigned n){
if(n==1)
return 1;
if(n%2)
return 1 + 2*function(n-2);
return 1 + function(n-1);
}
int main() {
unsigned x,i=1;
long v[61];
cin>>x;
while(function(i)<=x){
v[i] = function(i);
i++;
}
while(i>1){
cout<<v[--i]<<" ";
}
return 0;
}
Alte întrebări interesante
Limba română,
8 ani în urmă
Matematică,
9 ani în urmă
Matematică,
9 ani în urmă
Matematică,
9 ani în urmă
Matematică,
9 ani în urmă