| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 867 人关注过本帖
标题:请教一个问题(插入排序)
只看楼主 加入收藏
liyanhong
Rank: 3Rank: 3
来 自:水星
等 级:禁止访问
威 望:8
帖 子:1867
专家分:0
注 册:2008-5-3
收藏
 问题点数:0 回复次数:12 
请教一个问题(插入排序)
#include<stdio.h>
#include<stdlib.h>
#define ERROR 0
#define OVERFLOW -2
#define LIST_INIT_SIZE 100
#define LISTINCREMENT 10
typedef struct
{
  int *elem;
  int length;
  int listsize;
}SqList;
SqList L;
void ListInsert_Sq(int *L.elem,int i,int e)
{
  int *p,*q,*newbase;
  if(i<1||i>L.length-1)
    return ERROR;
  if(L.length>=L.listsize)
  {
    newbase=(int *)realloc(L.listsiza+LISTINCREMENT)*sizeof(int));
    if(!newbase)
       exit(OVERFLOW);
    L.elem=newbase;
    L.listsize+=LISTINCREMENT;
  }
  q=&(L.elem[i-1]);
  for(p=&(L.elem[L.length-1]);p>=q;--p)
    *(p+1)=*p;
  *q=e;
  ++L.length;
}

main()
{
  int i,l,e;
  L.elem=(int*)malloc(LIST_INIT_SIZE*sizeof(int));
  if(!L.elem)
    exit(OVERFLOW);
  L.length=10;
  L.listsize=LIST_INIT_SIZE;
  printf("Enter elememt: \n");
  for(i=0;i<L.length;i++)
  {
    scanf("%d",&L.elem[i]);
  }
  printf("Enter l: \n");
  scanf("%d",&l);
  printf("Enter e: \n");
  scanf("%d",&e)
  ListInsert_Sq(L.elem,l,e);
  for(i=0;i<L.length;i++)
  {
    printf("%d",L.elem[i]);
  }
}

[[it] 本帖最后由 liyanhong 于 2008-10-16 09:27 编辑 [/it]]
搜索更多相关主题的帖子: 插入排序 
2008-10-16 01:46
forever74
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:CC
等 级:版主
威 望:58
帖 子:1692
专家分:4282
注 册:2007-12-27
收藏
得分:0 
问题呢?
2008-10-16 01:48
liyanhong
Rank: 3Rank: 3
来 自:水星
等 级:禁止访问
威 望:8
帖 子:1867
专家分:0
注 册:2008-5-3
收藏
得分:0 
C:\Documents and Settings\Administrator\桌面\新建 文本文档.c(14) : error C2143: syntax error : missing '{' before '.'
C:\Documents and Settings\Administrator\桌面\新建 文本文档.c(14) : error C2059: syntax error : '.'
C:\Documents and Settings\Administrator\桌面\新建 文本文档.c(14) : error C2059: syntax error : ')'
C:\Documents and Settings\Administrator\桌面\新建 文本文档.c(50) : error C2146: syntax error : missing ';' before identifier 'ListInsert_Sq'
C:\Documents and Settings\Administrator\桌面\新建 文本文档.c(50) : warning C4013: 'ListInsert_Sq' undefined; assuming extern returning int
执行 cl.exe 时出错.

爱上你 是 我的错  可是离 开  又舍不得  听着你为我写的歌     好难过
如果说 我说如果  我们还 能  重新来过   不去计 较 谁对谁错  会怎么做
2008-10-16 01:50
forever74
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
来 自:CC
等 级:版主
威 望:58
帖 子:1692
专家分:4282
注 册:2007-12-27
收藏
得分:0 
syntax error就是语法错误呗
咋能整个结构体成员做形参呢?
你见过娶老婆娶一个脑袋的么?
2008-10-16 02:00
liyanhong
Rank: 3Rank: 3
来 自:水星
等 级:禁止访问
威 望:8
帖 子:1867
专家分:0
注 册:2008-5-3
收藏
得分:0 
问题有点严重  明天再来请教...

爱上你 是 我的错  可是离 开  又舍不得  听着你为我写的歌     好难过
如果说 我说如果  我们还 能  重新来过   不去计 较 谁对谁错  会怎么做
2008-10-16 02:12
liyanhong
Rank: 3Rank: 3
来 自:水星
等 级:禁止访问
威 望:8
帖 子:1867
专家分:0
注 册:2008-5-3
收藏
得分:0 
ListInsert_Sq(l,e);这样就正常了
但是这是全局变量的原因
不定义全局变量  换成局部变量
这个形参怎么传呢?
ListInsert_Sq(&L,l,e)->ListInsert_Sq(SqList *L,int l,int e);
不对吗  怎么出来那么多错

[[it] 本帖最后由 liyanhong 于 2008-10-16 08:41 编辑 [/it]]

爱上你 是 我的错  可是离 开  又舍不得  听着你为我写的歌     好难过
如果说 我说如果  我们还 能  重新来过   不去计 较 谁对谁错  会怎么做
2008-10-16 08:20
StarWing83
Rank: 8Rank: 8
来 自:仙女座大星云
等 级:贵宾
威 望:19
帖 子:3951
专家分:748
注 册:2007-11-16
收藏
得分:0 
LZ,说实在的,这代码是不是你写的?实在是太糟糕了……我改了N个错儿终于通过编译了,可是还是有一大堆的逻辑错误……哎,你的C功底不至于这么差吧?

专心编程………
飞燕算法初级群:3996098
我的Blog
2008-10-16 09:08
liyanhong
Rank: 3Rank: 3
来 自:水星
等 级:禁止访问
威 望:8
帖 子:1867
专家分:0
注 册:2008-5-3
收藏
得分:0 
是我套书上写的 还是要谢谢你哈

[[it] 本帖最后由 liyanhong 于 2008-10-16 09:23 编辑 [/it]]

爱上你 是 我的错  可是离 开  又舍不得  听着你为我写的歌     好难过
如果说 我说如果  我们还 能  重新来过   不去计 较 谁对谁错  会怎么做
2008-10-16 09:20
dkyingan
Rank: 1
等 级:新手上路
帖 子:34
专家分:0
注 册:2008-10-15
收藏
得分:0 
菜鸟一个  进来看看  帮兄弟们顶顶帖  呵呵呵
2008-10-16 09:42
liyanhong
Rank: 3Rank: 3
来 自:水星
等 级:禁止访问
威 望:8
帖 子:1867
专家分:0
注 册:2008-5-3
收藏
得分:0 
#include<stdio.h>
#include<stdlib.h>
#define ERROR 0
#define OVERFLOW -2
#define LIST_INIT_SIZE 100
#define LISTINCREMENT 10
typedef struct
{
  int *elem;
  int length;
  int listsize;
}SqList;
SqList L;
void ListInsert_Sq(int i,int e)
{
  int *p,*q,*newbase=0;
  if(i<1||i>L.length-1)
    exit(ERROR);
  if(L.length>=L.listsize)
  {
    newbase=(int*)realloc(newbase,(L.listsize+LISTINCREMENT)*sizeof(int));
    if(!newbase)
       exit(OVERFLOW);
    L.elem=newbase;
    L.listsize+=LISTINCREMENT;
  }
  q=&(L.elem[i-1]);
  for(p=&(L.elem[L.length-1]);p>=q;--p)
    *(p+1)=*p;
  *q=e;
  ++L.length;
}

main()
{
  int i,l,e;
  L.elem=(int*)malloc(LIST_INIT_SIZE*sizeof(int));
  if(!L.elem)
    exit(OVERFLOW);
  L.length=10;
  L.listsize=LIST_INIT_SIZE;
  printf("Enter elememt: \n");
  for(i=0;i<L.length;i++)
  {
    scanf("%d",&L.elem[i]);
  }
  printf("Enter l: \n");
  scanf("%d",&l);
  printf("Enter e: \n");
  scanf("%d",&e);
  ListInsert_Sq(l,e);
  for(i=0;i<L.length;i++)
  {
    printf("%d",L.elem[i]);
  }
  
}
差不多了
但应该还有很多逻辑错误

[[it] 本帖最后由 liyanhong 于 2008-10-16 09:48 编辑 [/it]]

爱上你 是 我的错  可是离 开  又舍不得  听着你为我写的歌     好难过
如果说 我说如果  我们还 能  重新来过   不去计 较 谁对谁错  会怎么做
2008-10-16 09:44
快速回复:请教一个问题(插入排序)
数据加载中...
 
   



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

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