Pagini recente » Cod sursa (job #1544648) | Diferente pentru home intre reviziile 594 si 593 | Cod sursa (job #2571491) | Cod sursa (job #247789) | Cod sursa (job #1260249)
#include <math.h>
#include <fstream>
#include <algorithm>
using namespace std;
ifstream is("fractal.in");
ofstream os("fractal.out");
long k,l,c,n,n2,aux,s;
int main()
{
is >> k >>c >>l;
n=pow(2,k);
n2=n;
do{
n2=n2/2;
n=n/2;
if ((l<=n2)&&(c<=n2)) {
aux=l;l=c;c=aux;
}
if ((l>n2)&&(c<=n2)){
l=l-n2;s+=n2*n2;}
if ((l>n2)&&(c>n2)){
s+=n2*n2*2;l=l-n2;c=c-n2;}
if ((l<=n2)&&(c>n2)){
c=c-n2;aux=l;l=(n+1-c);c=(n+1-aux);s+=n2*n2*3;
}
}
while (n2!=1);
os << s;
is.close();
os.close();
return 0;
}