Pagini recente » Cod sursa (job #699990) | Cod sursa (job #817275) | Cod sursa (job #3269756) | Cod sursa (job #672688) | Cod sursa (job #661293)
Cod sursa(job #661293)
#include <iostream>
#include <fstream>
using namespace std;
long R, i, j, rez=0;
short d;
int put(long nr) {
long i, k=1, putere=0;
for(i=1; k*d<=nr; i++) {
k*=d;
putere+=i;
}
return putere;
}
long p1;
int main() {
ifstream f("pascal.in");
ofstream g("pascal.out");
f>>R>>d;
// R!/((R-j)!*j!) = elementul j de pe linia R;
long p2, p3;
p1=put(R);
for(j=1; j<=int(R/2); j++) { //iau jumatate din elementele de pe linia R
p2=put(R-j);
p3=put(j);
if(p1 - p2 - p3 > 0) { rez++; }
}
rez*=2;
if(R%2 ==0) {
j=int(R/2)+1;
if(p1 -put(R-j) - put(j) > 0) { rez--; }
}
g<<rez;
f.close();
g.close();
return 0;
}