C ++中子字符串方法的问题[重复]

Posted

技术标签:

【中文标题】C ++中子字符串方法的问题[重复]【英文标题】:Issues with the substring method in C++ [duplicate] 【发布时间】:2018-07-05 20:20:40 【问题描述】:

给定字符串 IP 作为输入

int index, i=0;
string substr;
while(i!=-1 && IPv4)
            index=IP.find(".",i+1);
            substr=IP.substr(i,index);
            cout << substr << " found at index " << index << " with i= "<<i << endl;
            i=index;
        

输入:“172.16.254.1”

预期输出:

172 found at index 3 with i= 0
.16 found at index 6 with i= 3
.254 found at index 10 with i= 6
.1 found at index -1 with i= 10

结果输出:

172 found at index 3 with i= 0
.16.25 found at index 6 with i= 3
.254.1 found at index 10
.1 found at index -1 with i= 10

所以算法使用的值应该是正确的,但我得到了错误的子字符串。

任何意见将不胜感激

【问题讨论】:

How to use string.substr() function?的可能重复 【参考方案1】:

substr 采用索引和长度。

另外,将变量命名为与成员函数相同可能不是一个好主意。你可能想要:

ip_chunk = IP.substr(i, index - i);

【讨论】:

以上是关于C ++中子字符串方法的问题[重复]的主要内容,如果未能解决你的问题,请参考以下文章

JAVA String 如何去掉指定字符

Java中字符串中子串的查找共有四种方法(indexof())

Java中字符串indexof() 的使用方法

Java中字符串indexof() 的使用方法

Java中字符串indexof() 的使用方法

strings 与 strconv