标题:如何将数字扩大。请教各位老大!!
取消只看楼主
自学的数学
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:46
帖 子:967
专家分:4146
注 册:2017-11-15
结帖率:93.33%
已结贴  问题点数:10 回复次数:8 
如何将数字扩大。请教各位老大!!
如下一段代码:
#include<stdio.h>
#include <stdlib.h>
#define N 21
static void _fun( int,int,int** );
void print(FILE* fp, const int [][N][N] );
int a[1<<N][N][N];
int main( void )
{
   int i,j;
   int* p=NULL;
   unsigned k=1;
   FILE *fp;
    if ((fp = fopen ("D:\\数组21.txt", "a+")) == NULL)
    {
        printf("打开文件失败\n");
        exit(1);
    }
  for (i=0;i!=N/2;++i)
        k*=3;
   for (i=0;i!=k;++i)
    {
        p=a[i][1];
        {
            for (j=1;j!=N+1;++j)
                  a[i][0][j-1]=j;      
        }
       _fun(i,-(N/2-1),&p);
       _fun(i,N/2-1-(N+1)%2,&p);
    }
    print(fp, a);
    fclose(fp);
    return 0;
}
static void _fun( int k,int n,int** p )
{
     if (n>0)
        _fun(k/3,n-1,p);
   {
        int i=N+1;      
        while (--i)
        {
              **p=k%3;
              ++*p;
        }
   }
    if (n<0)
        _fun(k/3,n+1,p);
}
void print(FILE* fp, const int a[][N][N] )
{
    size_t i;
    unsigned k=1;
    for (i=0;i!=N/2;++i)
        k*=3;
    for (i=0;i!=k;++i)
    {
        size_t j;
        fprintf(fp,"i = %d\n",i);
        for (j=0;j!=N;++j)
        {
            size_t k;
            for (k=0;k!=N;++k)
                fprintf(fp,"%-4d",a[i][j][k]);
           fprintf(fp,"\n");
        }
        fprintf(fp,"\n");
    }
}
程序第三行的N取不大于20的数,都可以正常运行,但是取21,就不行了,请问,可以怎么修改呢?
要求:
 1):能否将N扩大到50或更大;
 2):还是要用到数组编程。
搜索更多相关主题的帖子: void int for ++i fprintf 
2018-05-02 16:18
自学的数学
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:46
帖 子:967
专家分:4146
注 册:2017-11-15
得分:0 
搞数学研究用的,跟行列式有关。俺喜欢研究数学。我还喜欢下围棋,通过下围棋,我还想到了一个编程方面的问题,到时候还得请教各位老大。谢谢!!
2018-05-03 07:06
自学的数学
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:46
帖 子:967
专家分:4146
注 册:2017-11-15
得分:0 
数组是必须要用到的,因为数组的计算是用数组的行列坐标来标识的,如果没有坐标,光是一堆数摆在这里,请问你怎么计算。
当然哦,用动态数组实现是可以考虑的。需要用到的时候再把数据从文件里面读取出来放入一个数组里面,暂时不需要用到的数
组可以选择重新覆盖这样来节省空间。都行。
2018-05-03 09:38
自学的数学
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:46
帖 子:967
专家分:4146
注 册:2017-11-15
得分:0 
这个思路好像蛮不错的,但是怎么操作呢??只要满足前面的那两点要求就可以了(1:能否将N扩大到50或更大;2:你这里说过可以不要数组,但是有关数组方面的计算如何计算呢?),这又是个难点。不好处理。
2018-05-03 11:13
自学的数学
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:46
帖 子:967
专家分:4146
注 册:2017-11-15
得分:0 
那用函数的方式,怎么编程呢?
2018-05-03 12:23
自学的数学
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:46
帖 子:967
专家分:4146
注 册:2017-11-15
得分:0 
回复 4楼 九转星河
顶一下。你说最大值是31.请问怎么弄呢?我只写到了20.写不下去了。请教了,谢谢!!
2018-05-04 19:01
自学的数学
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:46
帖 子:967
专家分:4146
注 册:2017-11-15
得分:0 
那怎么弄呢??
2018-05-05 16:02
自学的数学
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:46
帖 子:967
专家分:4146
注 册:2017-11-15
得分:0 
你是说,由于这样的数组太大,弄不出来,是吧?
2018-05-05 21:11
自学的数学
Rank: 13Rank: 13Rank: 13Rank: 13
等 级:贵宾
威 望:46
帖 子:967
专家分:4146
注 册:2017-11-15
得分:0 
既然如此,那这样吧:
因为数组的每一行的数字都一样,这样的话,那就将这样的N行N列的数组改成N行1列的数组来了,别的条件不变,这样就把原数组给压缩了,这样,是不是可以操作了呢??
2018-05-05 23:20



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-486564-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.514288 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved