编写函数jsValue,它的功能是:求Hofstadter数列中的第m项H(m)(m<1000),结果由函数返回。其中数列H(
编写函数jsValue,它的功能是:求Hofstadter数列中的第m项H(m)(m<1000),结果由函数返回。其中数列H(n)的定义为:
H(1)=H(2)=1
H(n)=H(n-H(n-1))+H(n-H(n-2))(n>2)
最后调用函数writeDat()读取50个数据m,分别得出结果且把结果输出到文件out.dat中。
例如:当t=997时,函数值为605。
部分源程序已给出。
请勿改动主函数main()和写函数writeDat()的内容。
include<stdio. h>
int jsValue(int m)
{
main ( )
{
int m;
m=300;
printf ("m=%d, k-%d\n", m, jsValue (m));
writeDat ( );
writeDat ( )
{
FILE *in, *out;
int i,m,s;
in= fopen ( "in. dar" , "r" );
ut=f open ( "out. dar" , "w" );
for (i=0; i<50; i++) {
fscanf (in, "%d", &m);
s=jsValue (m);
printf( "%d\n", s );
fprintf (out, "%d\n" , s );
}
fclose (in);
fclose (out);
int jsVelue(int m) { if (m0) return -1; /*参数错误,正常运行不会出现*/ if(m==1 || m==2) return 1; /*初值H[1]:H[2]=1*/ else return jsValue (m-jsValue (m-1)) +jsValue (m-jsValue (m-2)); /*调用jsValue递归计算H[k]*/ } /*解法二,递推*/ int jsValue(int m) { int H[1000], i; H[1]=1;H[2]=1; /*初值H[1]=H[2]=1*/ for (i=3;i=m;i++) { H[i] = H[i-H[i-1)] +H[i-H[i-2]]; /*H(k)(ki)的值都己计算完成,直接使用*/ } return H[m]; /*返回所求的值*/ } 解析:类型:序列计算。
关键点:分析序列定义,选择合适的方法生成和存储序列或序列中的特定值。
此题有两种解法:
1.按照定义编写递归函数;(计算量大,容易超时,慎用)。
2.保存所有值,从小到大递推求解。
经观测,某公路段在某时段内的车流量y(千辆/小时)与汽车的平均速度u(千米/小时)之间有函数关系y 数学 2020-05-17 …
如果在一条公路上,车辆的车头与紧跟在它后面的车头之恋的平均距离为d{m/辆},车辆的平均速度为u{ 数学 2020-07-04 …
101325Pa,373.15K下,水蒸发为水蒸气,以下哪种热力学函数变化为零?△U△H△S△G 物理 2020-07-19 …
MATLAB高手求教Error:Functiondefinitionsarenotpermitte 其他 2020-07-23 …
物理化学高手来帮帮忙啊!南大物化书上册第三章热力学的一个思考题,指出该过程中热力学函数Q,W,△U, 物理 2020-11-05 …
南大物化书上册第三章热力学的一个思考题,指出该过程中热力学函数Q,W,△U,△H,△S,△G,△A哪 其他 2020-11-05 …
1.集合U={1,5}为全集,S包含于U,T包含于U,S交T={2},S的补集交T={4},S的补集 数学 2020-12-08 …
中级微观经济学计算题假设一天有24小时,每天消费者选择S小时的睡眠,剩余时间工作.消费者的消费量因此 数学 2020-12-12 …
函数y=2分之1x,自变量x的取值范围是什么.已知二次函数y=x的平方+bx+c-t=0(u为实数) 数学 2021-01-27 …
∫区间0到X的e的-u次du我感觉应该是求e的-u次的原函数也就是e的-u次,然后属于复合函数在求- 数学 2021-02-16 …