| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 3887 人关注过本帖
标题:大佬帮忙看下这顺序表的错误 我真找不出来了
只看楼主 加入收藏
融起
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2021-9-18
收藏
 问题点数:0 回复次数:1 
大佬帮忙看下这顺序表的错误 我真找不出来了
#include <iostream>
using namespace std;

#define OK    (1)
#define ERROR (-1)

typedef int Status;
typedef int ElemType;
typedef struct SqList {
    ElemType* data;
    int length;
} SqList;

#define MAX_LENGTH        (100)

Status init(SqList* l);
Status destroy(SqList* l);
Status insert(SqList* l, ElemType x, int i);
Status remove(SqList* l, int i);
int locate(SqList * l, ElemType x);

#include "sqlist.h"

// 初始化顺序表
Status init(SqList* l)
{
    l->data = new ElemType[MAX_LENGTH];
   if (!l->data) exit(OVERFLOW);
   l->length = 0;
   return OK;
}

// 销毁顺序表
Status destroy(SqList* l)
{
    if (l->data) {
        delete[]l->data;
        l->data = NULL;
}
    l->length = 0;
    l->data = 0;
   
    return 0;
}

// 向顺序表指定位置i插入数据x
Status insert(SqList* l, ElemType x,int i)
{
  
    if ((i <1 )|| (i > l->length + 1)) return ERROR;
    if (l->length >= MAX_LENGTH) return ERROR;
    for (int j = l->length - 1; j >= i - 1; j--)
        l->data[j + 1] = l->data[j];
    l->data[i - 1] = x;
    ++l->length;
    return OK;
}

// 删除顺序表中指定位置i的数据
Status remove(SqList* l, int i)
{
    if ((i < 1) || (i > l->length)) return ERROR;
    for (int m = i; m < l->length - 1; m++)
        l->data[m - 1] = l->data[m];
    --l->length;
    return OK;
}

//定位顺序表中第一次出现数据i的位置,如果未找到返回-1
int locate(SqList* l, ElemType x)
{
    for ( int i = 0; i < l->length; i++)
        if (l->data[i] == x) return i + 1;
    return 0;
   
}
Status travel(SqList* l)
{
    for (int i = 0; i < l->length; i++) {
        cout << l->data[i];

        if (i != l->length - 1)
            cout << ",";
    }
    cout << endl;
    return OK;
}
int main()
{
    SqList l;
    init(&l);
    insert(&l, 1, 0);
    insert(&l, 2, 0);
    insert(&l, 3, 1);
    insert(&l, 4, 2);
    travel(&l);
    remove(&l, 0);
    travel(&l);
    int i = locate(&l, 4);
    cout << i << endl;
    destroy(&l);
    return 0;

}
要输出的是2,3,4,1      3,4,1   1
可是这个代码输出的是3,4   3,4       2

搜索更多相关主题的帖子: data int Status return length 
2021-09-18 15:52
andy292
Rank: 2
等 级:论坛游民
威 望:1
帖 子:86
专家分:13
注 册:2005-2-26
收藏
得分:0 
代码insert(&l, 1, 0) 与 insert(&l, 2, 0)应为填入数据的位置为0,小于1,所以没有进行操作,直接return 了。
2021-11-19 10:09
快速回复:大佬帮忙看下这顺序表的错误 我真找不出来了
数据加载中...
 
   



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

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