kunkundebasketba 2022-08-04 16:03 采纳率: 64.3%
浏览 88
已结题

这是王道数据结构串中求子串的代码,但是其中的判定合法条件为什么是pos+len-1而不是pos+len呢?而且在用sub存储子串时,其中的条件为什么是i-pos+1,而不是i-pos呢?

//求子串。用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;
}

  • 写回答

1条回答 默认 最新

  • 烟雨龙升 2022-08-04 18:26
    关注

    第pos个字符起长度为len的子串,子串末尾位置就是pos+len-1,如果你想用pos+len就需要改下if的条件为>=。
    存储子串时i-pos+1或是i-pos取决于你是否废弃ch[0]。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 系统已结题 8月12日
  • 已采纳回答 8月4日
  • 创建了问题 8月4日

悬赏问题

  • ¥15 shape_predictor_68_face_landmarks.dat
  • ¥15 slam rangenet++配置
  • ¥15 有没有研究水声通信方面的帮我改俩matlab代码
  • ¥15 对于相关问题的求解与代码
  • ¥15 ubuntu子系统密码忘记
  • ¥15 信号傅里叶变换在matlab上遇到的小问题请求帮助
  • ¥15 保护模式-系统加载-段寄存器
  • ¥15 电脑桌面设定一个区域禁止鼠标操作
  • ¥15 求NPF226060磁芯的详细资料
  • ¥15 使用R语言marginaleffects包进行边际效应图绘制