C++中的string.length()

         在C++中,如果你使用string.length()去获取一个字符串的长度,最后会返回一个无符号数(毕竟字符串的长度不可能是负的)。但这也经常会导致许多很难发现的问题,比如看下面这段代码。

int kmp(string mainstr, string mode)
{
	int len = mode.length();
	int len1 = mainstr.length();
	int* next = new int[len+1];
	getnext(mode, next);


	int k = 0, j = 0;
	while (k < len1 && j < len)
	{
		if (j == -1 || mainstr[k] == mode[j])
		{
			k++;
			j++;
		}
		else
		{
			j = next[j];
		}
	}
	if (j >= len)
	{
		return k - mode.length();
	}
	return -1;
}

        这段是kmp算法中匹配模式串和主串的代码,如果你在while (k < len1 && j < len)这里,或者是在最后的if (j >= len)中,把len替换成对应的str.length(),你会发现要么最后返回的是-1,要么就是连while循环都进不去。

while (k < len1 && j < len)

if (j >= len)
{
	return k - mode.length();
}

        这是因为,当一个数与一个无符号数进行大小比较时,编译器会把这两个数都转换为无符号数再进行比较,这就导致当j=-1去进行大小比较时,j会被自动转换为无符号整形4294967295,之后再去进行比较,这样自然没法得到想要的结果。

        解决方法很简单,在一开始定义一个int类型的长度进行类型转换即可。

int len = mode.length();
int len1 = mainstr.length();

(同时不建议将string.length()放入判断语句中,这样每进行一次判断都要调用一次这个函数)

  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值