数据结构串的定长顺序存储结构的删除strdelete-ss(&s,pos,len)操作
合集下载
相关主题
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
{
int i;
printf("串s的新值:\n");Βιβλιοθήκη Baidu
for(i=1;i<=s[0];i++)
printf("%c",s[i]);
}
void main()
{
int pos=0,len=0;
sstring s;
strinput(s);
printf("输入删除位置:\n");
scanf("%d",&pos);
#include <stdio.h>
#include <stdlib.h>
#include <string>
#define ERROR 0
#define ok 1
#define MAXSTRLEN 255
typedef int status;
typedef unsigned char sstring[MAXSTRLEN+1];
}
void strinput(sstring s)
{
int i=1,pos,len;
char ch;
printf("请输入串s:\n");
scanf("%c",&ch);
while(ch!='#')
{
s[i]=ch;
i++;
scanf("%c",&ch);
}
s[0]=i-1;
}
void strPrint(sstring s)
status strdelete(sstring &s,int pos,int len)
{
int i;
if(pos<1||pos>s[0]-len+1||len<0)
return ERROR;
for(i=pos+len;i<=s[0];i++)
s[i-len]=s[i];
s[0]-=len;
return ok;
printf("输入删除长度:\n");
scanf("%d",&len);
if (!strdelete(s,pos,len))
printf("ERROR");
else strPrint(s);
printf("\n");
}
int i;
printf("串s的新值:\n");Βιβλιοθήκη Baidu
for(i=1;i<=s[0];i++)
printf("%c",s[i]);
}
void main()
{
int pos=0,len=0;
sstring s;
strinput(s);
printf("输入删除位置:\n");
scanf("%d",&pos);
#include <stdio.h>
#include <stdlib.h>
#include <string>
#define ERROR 0
#define ok 1
#define MAXSTRLEN 255
typedef int status;
typedef unsigned char sstring[MAXSTRLEN+1];
}
void strinput(sstring s)
{
int i=1,pos,len;
char ch;
printf("请输入串s:\n");
scanf("%c",&ch);
while(ch!='#')
{
s[i]=ch;
i++;
scanf("%c",&ch);
}
s[0]=i-1;
}
void strPrint(sstring s)
status strdelete(sstring &s,int pos,int len)
{
int i;
if(pos<1||pos>s[0]-len+1||len<0)
return ERROR;
for(i=pos+len;i<=s[0];i++)
s[i-len]=s[i];
s[0]-=len;
return ok;
printf("输入删除长度:\n");
scanf("%d",&len);
if (!strdelete(s,pos,len))
printf("ERROR");
else strPrint(s);
printf("\n");
}