大马强 发表于 2020-4-5 18:55:15

鱼油们看看这个软件的区别

https://s1.ax1x.com/2020/04/05/GDf7wR.png
下面这个代码CodeBlock能用但dev用不了
我觉得下面这代码问题有问题呀,是我太菜了吗{:10_277:}
我觉得问题是 BOOL 改为enum BOOL 还有那个形参真的看不懂
求解答
#include <conio.h>
#include <dos.h>
#include <stdio.h>
#include <stdlib.h>
#define LEN sizeof(LNode)//定义LEN为一个//节点的长度
enum BOOL{False,True};//定义BOOL型
typedef struct node
{char data;    //数据域
struct node *next;//指向下一个节点的指针
}LNode,*LinkList;
void CreatList(LinkList &,int);   //生成一个//单链表
BOOL ListInsert(LinkList &,int,char); //在单//链表中插入一个元素
BOOL ListDelete(LinkList &,int,char &); //在//单链表中删除一个元素
BOOL ListFind_keyword(LinkList,char,int &); //按关键字查找一个元素
BOOL ListFind_order(LinkList,char &,int);//按序号查找一个元素
void ListPrint(LinkList);      //显示单链表
int main()
{LinkList L;
BOOL temp;
int num,loc,flag=1;
char j,ch;

//---------------------程序解说-----------------------
printf("本程序实现链式结构的线性表的操作。\n");
printf("可以进行插入,删除,定位,查找等操作。\n");
//----------------------------------------------------
printf("请输入初始时链表长度:"); //输入生成单链表时的元素个数
scanf("%d",&num);
CreatList(L,num);      //生成单链表
ListPrint(L);         
while(flag)
   { printf("请选择:\n");
   printf("1.显示所有元素\n");//显示链//表元素
   printf("2.插入一个元素\n");//插入链//表元素
   printf("3.删除一个元素\n");//删除链//表元素
   printf("4.按关键字查找元素\n");//按//关键字查找
      printf("5.按序号查找元素\n"); //按序号//查找
      printf("6.退出程序      \n");//退出
      scanf(" %c",&j);
      switch(j)
        {case '1':ListPrint(L); break;
       case '2':{printf("请输入元素(一个字符)和要插入的位置:\n");
                   printf("格式:字符,位置;例如:a,3\n");
                   scanf(" %c,%d",&ch,&loc);       //输入要插入的元素和要插入的位置
                   temp=ListInsert(L,loc,ch);      //插入
                   if(temp==False) printf("插入失败!\n"); //插入失败
                   else printf("插入成功!\n"); //成//功插入
                   ListPrint(L);
                   break;
                  }
       case '3':printf("请输入要删除的元素所在位置:");
                  scanf("%d",&loc);            //输入要删除的节点的位置
        temp=ListDelete(L,loc,ch);    //删除
                  if(temp==False) printf("删除失败!\n"); //删除失败
                  else printf("成功删除了一个元素:%c\n",ch);   //删除成功,显示该元素
                  ListPrint(L);
                  break;
       case '4':if(L->next==NULL)                   //链表为空
                     printf("链表为空!\n");
                  else{printf("请输入要查找的元素(一个字符):");
                     scanf(" %c",&ch);                //输入要查找的元素
                     temp=ListFind_keyword(L,ch,loc); //按关键字//查找
                     if(temp==False) printf("没有找到该元素!\n"); //查找失败
                     else printf("该元素在链表的第%d个位置。\n",loc);
                                           //成功查找,显示该元素位置
                      }
                  break;
       case '5':if(L->next==NULL)                   //链表为空
                     printf("链表为空!\n");
                  else{printf("请输入要查找的位置:");
                     scanf("%d",&loc);    //输入//要查找的元素的位置
                     temp=ListFind_order(L,ch,loc); //按序号查找
                     if(temp==False) printf("该位置不存在!\n"); //查找失败
                     else printf("第%d个元素是:%c\n",loc,ch);
                      //成功查找,显示该元素
                      }
                  break;
       default:flag=0;printf("程序结束,按任意键退出!\n");
        }
    }
getch();
return 0;
}
void CreatList(LinkList &v,int n)
{//生成一个带头结点的有n个元素的单链表
int i;
LinkList p;
v=(LinkList)malloc(LEN); //生成头结点
v->next=NULL;
printf("请输入%d个字符:例如:abcdefg\n",n);
getchar();
for(i=n;i>0;--i)
    {p=(LinkList)malloc(LEN); //生成新结点
   scanf("%c",&p->data);
      p->next=v->next;                               //将未完成的代码补全,此处添加一条代码
   v->next=p;
    }
}
BOOL ListInsert(LinkList &v,int i,char e)
{//在单链表的第i各位置插入元素e,成功返回//True,失败返回False
LinkList p,s;
int j=0;
p=v;
while(p&&j<i-1) {p=p->next;++j;} //查找第//i-1个元素的位置
if(!p||j>i-1) return False;//没有找到
s=(LinkList)malloc(LEN);   //生成一个新//结点   
s->data=e;            
   s->next=p->next;                                     //将未完成的代码补全,此处添加一条代码
   //提示:将新结点插入到单链表中,即修改指针,完成插入操作
p->next=s;
return True;
}

BOOL ListDelete(LinkList &v,int i,char &e)
{//在单链表中删除第i个元素,成功删除返回//True,并用e返回该元素值,失败返回False
LinkList p,q;
int j=0;
p=v;
while(p->next&&j<i-1)//查找第i-1个元素位//置
    {p=p->next;++j;}
if(!(p->next)||j>i-1) return False; //查找//失败
q=p->next;
   p->next=q->next   ;                   /*将未完成的代码补全,此处添加一条代码,提示:删除该元素*/   
   e=q->data;               /*将未完成的代码补全,此处添加一条代码,提示:e取得该元素值,即修改指针,删除结点q*/
free(q);         //释放该元素空间
return True;
}

BOOL ListFind_keyword(LinkList v,char e,int &i)
{//在单链表中查找关键字为e的元素,成功返回//True,并用i返回该元素位置,
//失败返回False
i=1;
LinkList p;
p=v->next;
while((p->data!=e)&&(p->next!=NULL))//p指//针指向下一个,直到
    {p=p->next;i++;}                        //找到或到链表尾为止
if(p->data!=e)                      //该元//素在链表中不存在
   return False;
else return True;
}

BOOL ListFind_order(LinkList v,char &e,int i)
{//在单链表中查找第i个元素,成功返回True,//并用e返回该元素值,
//失败返回False
LinkList p;
int j=0;
p=v;
while((p->next!=NULL)&&j<i/*将未完成的代码补全,此处添加一条代码, 提示:移动指针,直到找到第i个元素*/)
      {p=p->next;++j;}
if(j!=i) return False; //查找失败
else {e=p->data;       //查找成功,用e取得//该元素值
       return True;
      }
}
void ListPrint(LinkList v)   
{//显示链表所有元素
LinkList q;
q=v->next;
printf("链表所有元素:");
while(q!=NULL)
   {printf("%c ",q->data);q=q->next;}
printf("\n");
}

大马强 发表于 2020-4-6 07:45:24

好心鱼友们帮忙康康{:10_256:}

KevinHu 发表于 2020-4-6 08:57:58

布尔类型在C语言里不是_Bool吗?

倒戈卸甲 发表于 2020-4-6 10:37:38

KevinHu 发表于 2020-4-6 08:57
布尔类型在C语言里不是_Bool吗?

看代码啊,这里别人自定义了enum BOOL

倒戈卸甲 发表于 2020-4-6 10:42:59

现在没有这两款软件所以无法回答。一般来说,在一个编译器通过,在另一个编译器无法通过,这种情况不是代码本身的问题。要看不通过编译器的错误提示,可能需要你导入什么库,或者声明某个宏,都有可能。你可以根据错误提示的关键词去百度。或者等一个dev编译器的老玩家

大马强 发表于 2020-4-6 11:08:58

倒戈卸甲 发表于 2020-4-6 10:42
现在没有这两款软件所以无法回答。一般来说,在一个编译器通过,在另一个编译器无法通过,这种情况不是代码 ...

哦哦,还有一个问题想问问
就是声明了结构体类型名字为
*LinkList;
然后
LinkList l
那这个   BOOL ListInsert(LinkList &,int,char);
为什么还有形参还有个&取地符

倒戈卸甲 发表于 2020-4-6 12:34:53

大马强 发表于 2020-4-6 11:08
哦哦,还有一个问题想问问
就是声明了结构体类型名字为
*LinkList;


取址符&出现在数据类型标识符的后面时表示引用,例如存在整形变量b,此时int& a=b,表示a为b的引用。其效果为绑定a和b,a,b成为同一块内存的两个名字,所以a的修改会引起b的修改,反之亦然。同样,在函数传参时,其效果为地址传递而非值传递。
页: [1]
查看完整版本: 鱼油们看看这个软件的区别