アットウィキロゴ

pro0902x

#include <stdio.h>
#include <math.h>
int main(void){
double a,beta,ks,ls,h,k1,l1,r1,w1,c1,e,n1,uc;
double k[101],cx[101],cp[101],lx[101],lp[101];
int n,n2,n3,t;
beta = 0.95;
a = 0.33;  
ls=(1-a)/(2-a);
ks = ls * pow((1 / beta - 1) / a, 1 / (a - 1));
h = 2 * ks / 100;
for (n=1;n<=100;n++){
k[n] = n * h;
lx[n]=ls;
}  
for (n=1;n<=100;n++){
cx[n] = pow(k[n], a) * pow(lx[n],1 - a);
}
t = 0;
while(t<100){
for (n=10;n<=90;n++){
k1 = k[n] + pow(k[n],a) * pow(lx[n] , 1 - a) - cx[n];
n1 = k1 / h;
n2 = floor(n1);
n3 = n2 + 1;
c1 = cx[n2] + (n1 - n2) * (cx[n3] - cx[n2]);
l1 = lx[n2] + (n1 - n2) * (lx[n3] - lx[n2]);
r1 = a * pow(k1 ,a - 1) * pow(l1 ,1 - a);
cp[n] = c1 / (beta * (1 + r1));
w1 = (1 - a) * pow(k[n],a) * pow(lx[n],-a);
lp[n] = 1 - cx[n] / w1;
}
e = 0;
for (n=10;n<=90;n++){
e = e + pow(cx[n] - cp[n],2) + pow(lx[n] - lp[n], 2);
}
for (n=10;n<=90;n++){
cx[n] = cp[n];
lx[n] = lp[n];
}
if (e<0.001) t=1000;
t=t+1;
}
for (n=10;n<=90;n++){
printf("%f",cx[n]);
printf("\n");
}
return 0;
}
最終更新:2010年09月04日 03:11