当前时区为 UTC + 8 小时



发表新帖 回复这个主题  [ 4 篇帖子 ] 
作者 内容
1 楼 
 文章标题 : [已解决]C语言:函数返回数组指针编译报错
帖子发表于 : 2008-08-11 18:00 
头像

注册: 2007-07-30 12:06
帖子: 11
地址: Tangshan,Hebei
送出感谢: 0 次
接收感谢: 0 次
flumer@flumer-ubuntu7:~/discretemath$ cc 2-1.c
2-1.c: In function ‘main’:
2-1.c:51: error: incompatible types in assignment

2-1.c
代码:
#include<stdio.h>
#include<stdlib.h>

int *getcode(int *a,int arr,int n)
{
   int i,k=0,notfull;
   int iden[arr],idenfull[arr];
   for(i=n;i>0;i--)
      iden[i]=++k;
   for(i=n;i>0;i--)
      idenfull[i]=a[i]-iden[i];
   for(i=1;i<arr;i++)
      if(idenfull==0)continue;
      else break;
   a[i]++;
   k=a[i];
   while(i!=1){
      k++;
      i--;
      a[i]=k;
   }
   return a;
}

/*
int
pow(int a,int b)
{
   int i;
   int tmp=a;
   for(i=1;i<b;i++)
      a=a*tmp;
   return a;
}*/
int
main(void)
{
   int n,i,j,cnt;
   printf("Input n:");
   scanf("%d",&n);
   int a[n+1];
   if(n==0){
      printf("{NULL}\n");
      exit(1);
   }
   printf("{NULL}\n");
   a[1]=1;
   cnt=n;
   for(i=1;i<=n*n;i++){
      a=getcode(a,n+1,n);/*这里是第五十行*/
      for(j=n;j>0;j--){
         if(a[j]==0)cnt--;
         if(a[j]!=0&&j==cnt){
            printf("{%d",a[j]);
            break;
         }
         if(a[j]!=0){
            if(j==1)
               printf(",%d}\n");
            else
               printf(",%d",a[j]);
         }
      }
   }
   return 0;
}


望高手指教,多谢!


最后由 flumer 编辑于 2008-08-12 10:30,总共编辑了 1 次

页首
 用户资料  
 
2 楼 
 文章标题 :
帖子发表于 : 2008-08-11 18:16 

注册: 2007-06-02 15:56
帖子: 6
送出感谢: 0 次
接收感谢: 0 次
a=getcode(a,n+1,n);/*这里是第五十行*/

a是整形数组指向数组的第一个元素
a指向的位置是固定的不能更改
所以不能这样赋值


页首
 用户资料  
 
3 楼 
 文章标题 :
帖子发表于 : 2008-08-11 19:13 
头像

注册: 2006-07-02 11:16
帖子: 12522
地址: 廣州
送出感谢: 0 次
接收感谢: 8
a=getcode(a,n+1,n);/*这里是第五十行*/

改成

getcode(a,n+1,n);/*这里是第五十行*/

就可以了


_________________
^_^ ~~~
要理解递归,首先要理解递归。

地球人都知道,理论上,理论跟实际是没有差别的,但实际上,理论跟实际的差别是相当大滴。


页首
 用户资料  
 
4 楼 
 文章标题 :
帖子发表于 : 2008-08-12 10:29 
头像

注册: 2007-07-30 12:06
帖子: 11
地址: Tangshan,Hebei
送出感谢: 0 次
接收感谢: 0 次
多谢。


页首
 用户资料  
 
显示帖子 :  排序  
发表新帖 回复这个主题  [ 4 篇帖子 ] 

当前时区为 UTC + 8 小时


在线用户

正在浏览此版面的用户:没有注册用户 和 3 位游客


不能 在这个版面发表主题
不能 在这个版面回复主题
不能 在这个版面编辑帖子
不能 在这个版面删除帖子
不能 在这个版面提交附件

前往 :  
本站点为公益性站点,用于推广开源自由软件,由 DiaHosting VPSBudgetVM VPS 提供服务。
我们认为:软件应可免费取得,软件工具在各种语言环境下皆可使用,且不会有任何功能上的差异;
人们应有定制和修改软件的自由,且方式不受限制,只要他们自认为合适。

Powered by phpBB © 2000, 2002, 2005, 2007 phpBB Group
简体中文语系由 王笑宇 翻译