1.1

Implement an algorithm to determine if a string has all unique characters. What if you can not use additional data structures?

1)使用附加结构:

这里需要假定的是字符都是ASCII码(1个字节表表示),大小256的为扩展ASCII码(0-255),128为标准ASCII(0-127)

bool hasAllUniqueChar(string str){
	int a[256];
	memset(a,0,sizeof(a));
	for(int i=0;i<str.length();i++){
		a[str[i]]++;
		if(a[str[i]]>1)
			return false;
	}
	return true;
}

评:答案中hash数组使用的不是int而是bool这样能减少空间的开销,这是我所没有想到的

2)不使用附加结构:

bool hasAllUniqueChar(string str){
	for(int i=0;i<str.length();i++)
		for(int j=i+1;j<str.length();j++){
			if(str[i]==str[j])
				return false;
		}
	return true;
}
评:答案中提出当字符都是小写字母的时候可以使用位运算来操作,只需要一个整形变量,空间复杂度为O(1),代码如下:

bool hasAllUniqueChar(string str){
	int test=0;
	for(int i=0;i<str.length();i++){
		int pos=str[i]-'a';
		if((1<<pos)&test)
			return false;
		test|=(1<<pos);
	}
	return true;
}
这儿使用了一个变量,如果任何附加变量也不使用的话,答案给出了当str结构可以破坏的时候对str进行排序,然后用两个指针i和j,不断向后移动,判断str[i]是否和str[j]相等。


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值