线性表1.0(数组实现)

线性表1.0(s数组实现)

#include<stdio.h>
#include<malloc.h>
int Length=0;
void Menu(void);
int Choice(void);
int *initialize(int n);
void add(int array[],int index,int value);
int delet(int array[],int index);
int find(int array[],int index);
void show(int array[]);
int main()
{
    int flag=1,index=0,value=0,*array;
    Menu();
    while(flag)
    {
        switch(Choice())
        {
            case 0:
                    flag=0;
                    break;
            case 1:
                    printf("请输入初始化数组长度:\n");
                    scanf("%d",&Length);
                    array=initialize(Length);
                    break;
            case 2:
                    printf("请输入添加的位置和数值:\n");
                    scanf("%d%d",&index,&value);
                    add(array,index,value);
                    break;
            case 3:
                    printf("请输入删除的位置:\n");
                    scanf("%d",&index);
                    delet(array,index);
                    break;
            case 4:
                    printf("请输入查询的位置:\n");
                    scanf("%d",&index);
                    find(array,index);
                    break;
            case 5:
                    show(array);
                    break;
        }
    }
    return 0;
}
void Menu(void)
{
    printf("选项菜单:\n");
    printf("0.退出\n");
    printf("1.初始化长度为n的数组\n");
    printf("2.在数组指定位置添加数值\n");
    printf("3.删除数组指定位置数值\n");
    printf("4.查询数组指定位置数值\n");
    printf("5.显示当前数组\n");
}
int Choice(void)
{
    int choice;
    printf("请输入你想进行的操作:\n");
    scanf("%d",&choice);
    return choice;
}
int *initialize(int n)
{
    int *p,i;
    p=(int*)malloc(sizeof(int)*n);
    for(i=0;i<n;i++)
        p[i]=0;
    return p;
}
void add(int array[],int index,int value)
{
    if(index<0||index>=Length)
        printf("添加数值失败\n");
    else
    {
        array[index]=value;
        printf("添加数值成功\n");
    }
}
int delet(int array[],int index)
{
    int value,i;
    if(index<0||index>=Length)
    {
        printf("删除位置数值失败\n");
        return -1;
    }
    else
    {
        value=array[index];
        for(i=index;i<Length-1;i++)
            array[i]=array[i+1];
        Length--;
        printf("删除的数值为%d\n",value);
        return value;
    }
}
int find(int array[],int index)
{
    if(index<0||index>=Length)
    {
        printf("查询失败\n");
        return -1;
    }
    else
    {
        printf("查询位置数值为%d\n",array[index]);
        return array[index];
    }
}
void show(int array[])
{
    int i;
    printf("数组长度为%d\n",Length);
    for(i=0;i<Length;i++)
        printf("%d ",array[i]);
    printf("\n");
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值