鱼C论坛

 找回密码
 立即注册
查看: 2023|回复: 5

[已解决]这个MaxSize和这个n 效果一样的,感觉搞个MaxSize 多余

[复制链接]
发表于 2018-11-1 16:27:46 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 大可爱 于 2018-11-1 16:30 编辑

算法 : 在长度为n 的线性表A的第i 个位置插入一个新数据元素item
#define MaxSize 1000
ElemType A[MaxSize] ;
int n ;
void INSERTLIST (ElemType A[],int &n,int i,ElemType item)
{
        int j;
        if (n == MaxSize || i < 1 || i > n+1)
        {
                ERRORMESSAGE ("表满或插入位置不正确!");/*插入失败*/
        }
        for (j = n-1;j >= i-1;j--)
        {
                A[j+1] = A[j];                                                        /*数据元素依次后移一个位置*/
        }
        A[i-1] = item;                                                                /*将item插入表的第i个位置 */
        n++;                                                                                /*表的长度加1*/
}
自己对这个算法的形参不是很理解,写了个代码
#include<stdio.h>
#define MaxSize 5
int A[MaxSize];
int n;

void INSERTLIST (int A[],int &n,int i,int item )
{
       
        if (n == MaxSize || i < 1 || i > n+1)
        {
                printf ("表满或插入位置不正确!");/*插入失败*/
                return ;
        }
        int j;
        //n++;
        for (j = n-1;j >= i-1;j--)
        {
                A[j+1] = A[j];                                                        /*数据元素依次后移一个位置*/
        }
        A[i-1] = item;                                                                /*将item插入表的第i个位置 */
        n++;                                                                                /*表的长度加1*/
}

int main()
{
    int a[100] = {10,20,30,40};
    n = 4;
    INSERTLIST (a,n,2,5);
    for (int i = 0; i < n; i++)
    {
        printf("%d ",a);
    }
   
    return 0;
}




最佳答案
2018-11-1 16:38:45
MaxSize 在这里是线性表的最大长度,也就是这个线性表的容量;
n表示当前线性表的有效数据长度(线性表实际上放了多少数据)
不是同一个东西。

当放满的时候,如果还要求放进去,应当做相应处理。

printf ("表满或插入位置不正确!");/*插入失败*/
                return ;
捕获.PNG
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2018-11-1 16:34:45 | 显示全部楼层
还有这个表长n 是自己数出来的然后给程序,感觉怪怪的。说好的顺序线性表是适合存储大量只读取不删除插入的方法,那实际中,那么多数据,一个个数是不可能的。所以感觉奇怪。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-11-1 16:38:45 | 显示全部楼层    本楼为最佳答案   
MaxSize 在这里是线性表的最大长度,也就是这个线性表的容量;
n表示当前线性表的有效数据长度(线性表实际上放了多少数据)
不是同一个东西。

当放满的时候,如果还要求放进去,应当做相应处理。

printf ("表满或插入位置不正确!");/*插入失败*/
                return ;
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-11-1 17:41:21 | 显示全部楼层
哈哈,又写了个删除元素的代码
#include<stdio.h>
#define MaxSize 5
int A[MaxSize];
int n;

void DELETELIST (int A[],int &n,int i)
{
        int j;
        if ( i < 1 || i > n)
        {
                printf ("表空或删除位置不正确!");  /* 删除失败 */
        }
        for (j = i;j < n;j++)
        {
                A[j-1] = A[j];                                                        /*数据元素依次迁移一个位置*/
         }
         n--;                                                                                /*表长减1*/
}

int main()
{
    int a[100] = {10,20,30,40};
    n = 4;
    DELETELIST (a,n,2);
    for (int i = 0; i < n; i++)
    {
        printf("%d ",a[i]);
    }
   
    return 0;
}
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-11-1 17:46:41 | 显示全部楼层
大可爱 发表于 2018-11-1 17:41
哈哈,又写了个删除元素的代码
#include
#define MaxSize 5

还要加一个判断,n大于0吧
n == 0时没法删除。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2018-11-1 18:39:47 | 显示全部楼层
风扫地 发表于 2018-11-1 17:46
还要加一个判断,n大于0吧
n == 0时没法删除。

确实要判断
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-4-24 05:18

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表