//求子串。用Sub返回串S的第pos个字符起长度为len的子串
bool SubString(SString &Sub,SString S,int pos,int len){
//子串范围越界
if(pos+len-1 > S.length){
return false;
}
for(int i=pos;i<pos+len;i++){
Sub.ch[i-pos+1] = S.ch[i];
}
Sub.length = len;
return true;
}
这是王道数据结构串中求子串的代码,但是其中的判定合法条件为什么是pos+len-1而不是pos+len呢?而且在用sub存储子串时,其中的条件为什么是i-pos+1,而不是i-pos呢?
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
1条回答 默认 最新
- 烟雨龙升 2022-08-04 18:26关注
第pos个字符起长度为len的子串,子串末尾位置就是pos+len-1,如果你想用pos+len就需要改下if的条件为>=。
存储子串时i-pos+1或是i-pos取决于你是否废弃ch[0]。本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 3无用
悬赏问题
- ¥15 shape_predictor_68_face_landmarks.dat
- ¥15 slam rangenet++配置
- ¥15 有没有研究水声通信方面的帮我改俩matlab代码
- ¥15 对于相关问题的求解与代码
- ¥15 ubuntu子系统密码忘记
- ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
- ¥15 保护模式-系统加载-段寄存器
- ¥15 电脑桌面设定一个区域禁止鼠标操作
- ¥15 求NPF226060磁芯的详细资料
- ¥15 使用R语言marginaleffects包进行边际效应图绘制