作业一 数据结构学习

#include <stdio.h> 
#include<malloc.h>

#define MaxSize 20
#define Size 5 

typedef struct{
   int*data;
   int dlen;
   int len;        
}SqList;
/*初始化线性表*/
void Sq_Init(SqList*L){
  L->data=(int*)malloc(MaxSize*sizeof(int));
  
  if(!L->data){
      printf("分配内存空间失败!");     
  }
  else{
    L->dlen=0;
    L->len=MaxSize;    
  } 
};
/*打印线性表*/
void Printf_Sq(SqList*L){
   int i;
  if(!L->data){
    printf("线性表不存在");    
  } 
  else{
     for(i=0;i<L->dlen-1;i++){
     printf("%d\t",L->data[i]);    
   }    
  } 
}
/*增加线性表空间*/
void ZSq(SqList*L){
    //重更新分配存储空间 
    int*newbase=(int*)realloc(L->data, (L->dlen + Size) * sizeof(int));    
    if(!newbase){
      printf("增加存储空间失败");
    }
    else {
     L->data=newbase;
     L->len+=Size;    
    }

/*插入数据到线性表,输入数据在表尾部*/
void InsetData(SqList*L,int x){
    if(!L->data){
     printf("线性表不存在");    
    }    
    else {
      int i;
      if(L->dlen==0){
          L->dlen=1;
      }
      i=L->dlen-1;
      L->data[i]=x;
      L->dlen++;        
    } 
};
/*销毁线性表*/
void DestryList(SqList*L){
  free(L->data);    
};
/*重置线性表*/
void ClearList(SqList*L){
    L->dlen=0;
}; 
/*给定一个位置插入数据*/
void Insetother(SqList*L,int i,int x){
 //插入线性表,位置,数据
  int j;
  L->dlen++;
  for(j=L->dlen-1;i-1<=j;j--){
       L->data[j+1]=L->data[j];             
  }
     L->data[i-1]=x; 
};
/*删除指定位置的数据*/ 
void Delete(SqList*L,int x){
  //线性表,数据的位置
  int j;
  if(1>x |x>L->dlen ){
      printf("删除数据不在线性表数据范围");
  }
  else {
      for(j=x;j<=L->dlen-1;j++){
        L->data[j-1]=L->data[j];    
  } 
  } 
   L->dlen--;
   printf("删除成功\n");      
};

int main(){
  
  SqList L;
  int y,i,x,a,b;    
  
  Sq_Init(&L);
  printf("请输入线性表数据的个数:");
  scanf("%d",&y);
  printf("%d\n",y);
  for(i=0;i<y;i++){
      scanf("%d",&x);
      InsetData(&L,x);
  }
  printf("数据表中的内容:\n");
  Printf_Sq(&L);
  printf("\n");     
  printf("请选择插入数据的位置及数据:\n");
  scanf("%d%d",&a,&b);
  Insetother(&L,a,b);
  Printf_Sq(&L);
  printf("\n");
  printf("请选择清除数据的位置及数据:\n");
  scanf("%d",&b);
  Delete(&L,b);
  Printf_Sq(&L);
  DestryList(&L);        

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Mr pan cheng

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值