数据结构--串的顺序储存

用一组地址连续的存储单元存储串值的字符序列,为每个定义的串变量分配一个固定长度的存储区。

串的实际长度可以在预定长度的范围内随意,超过预定义长度的串值则被舍去,称之为“截断”。

对于串长的表示有两种:一是以下标为0的数组分量存放串的实际长度;二是在串值后面加一个不计入串长的结束标记字符。 这里串的顺序存储使用第一种方式记录串长。

//串的顺序存储方式
#include<stdio.h>
#include<stdlib.h>
#include<string.h>

#define OK 1
#define ERROR 0

#define MAXSIZE 255
typedef unsigned char SString[MAXSIZE+1];
//这种定义方式的理解
//SString S 就等价于 unsigned char S[MAXSIZE+1]

typedef int Status;

Status StrAssign(SString S,char *ch)
{
  int i;
  if(strlen(ch)>MAXSIZE) return ERROR;
  S[0]=strlen(ch);
  for(i=1;i<=S[0];i++)
  {
    S[i]=*(ch+i-1);
  }
  return OK;
}

Status StrCopy(SString S,SString T)
{
  for(int i=0;i<T[0];i++)
  {
    S[i]=T[i];
  }
  return OK;
  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值