|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
- #include<stdio.h>
- int main()
- {
- int in,inb,sum = 0;
- int a,b;
- int *m,*n;
- printf("please print a number:");
- scanf("%d",&in);
- inb = in * in * in;
- printf("inb=%d\n",inb);
- for (a=1,b=1,m=&a,n=&a; sum<inb; n+=4,b+=2,*n=b)
- {
- sum += *n;
- printf("sum=%d\n",sum);//
- if (sum > inb)
- {
- for (; sum > inb; m+=4)
- {
- printf("*m=%d\n",*m);//
- sum -= *m;
- }
- }
- }
- printf("%d =",sum);
- for (;m<n ;m+=4)
- {
- printf(" %d +",*m);
- }
- printf(" %d\n",*m);
- return 0;
- }
复制代码
其中一些printf是我用来调试的
指针*m往后读4个字节显示的与预期不一样
本帖最后由 风过无痕1989 于 2020-12-7 19:05 编辑
你早说是验证尼科彻斯定理,我昨天就给你程序了,昨天看你的程序,就没有看明白要干什么,也就没有理会你了
- // 验证尼科彻斯定理:任何一个正整数的立方都可以写成一串连续奇数的和
- #include<stdio.h>
- #include<math.h>
- int main()
- {
- int a,b,s,i,j,first;
- int total = 0;
- printf("一个数 N 立方等于 N 个 N 的平方之和,即:N ^ 3 = N * N ^ 2\n");
- printf("即:(N ^ 2 - N) + (N ^ 2 - (N - 1)) ... + N ^ 2 ... + (N ^ 2 + (N - 1) + (N ^ 2 + N)\n");
- printf("为了确保首项为奇数,故有:N ^ 2 - N + 1\n");
- printf("请输入一个整数:");
- scanf("%d",&a);
-
- b=pow(a,3);
- printf("%d 的立方:b = %d\n",a,b);
- s = a * a - a + 1;
- first = s;
- for (i = 1;i < b;i++)
- {
- total += s;
- s += 2;
- if (total == b)
- {
- printf("b 由 %d 个奇数相加得到\n",i);
- break;
- }
- }
- printf("b = %d",first);
- for (j = 2;j < 2 * i;j=j + 2)
- {
- printf(" + %d",first + j);
- }
- printf("\n");
- }
复制代码
|
|