Cracking the coding interview--Q1.1

作者: ustcweijie

1. 题目

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

理解:设计一个算法判断字符串中字符是否有重复。要求不能使用附加数据结构(理解为只用基本的数据类型)

2. 思路

由于字符串组成的基本单位是字符,为了不失一般性,此处考虑的作用域为整个ASCII 字符集,建立一个计算器数组 c[i], 长度为256, c[i]表示ASCII码等于i的字符出现的次数。扫描待判断的字符串并统计字符出现的次数,当某个字符计数 > 1 即表示有重复字符出现。

3. 代码

C/C++代码实现:
bool IsUnique(string s)
{
	int c[256];
	for(int i = 0; i < 256; i++)
		c[i] = 0;
	for(int j = 0; j < s.length(); j++)
	{
		c[s[j]] += 1;
		if(c[s[j]] > 1)
			return false;
	}
	return true;
}

4. 分析

4.1. 时间复杂度:

根据代码发现该算法的时间复杂度为O(n). 空间复杂度为计数器数组的长度256字节. 为了节省空间作者hawstein 利用长度为8的int 数组(32字节=256bits)的256位实现相同的目的,请参考:http://hawstein.com/posts/1.1.html

4.2. 关于ASCII码

ASCII 码字符集用一个字节长度的整数表示 256个不同的字符,根据编译器的不同,char 分为signed char 和unsigned  char两种情况,在上述代码中,s[j] 表示字符串中位于j位置上的字符对应的ASCII 编码。 当编译器把char 解释成在signed char 时候,ASCII码-> int 转换时要特别小心,对于0~127之间的字符,可以直接赋值 int v = s[j],但是对于128 ~255 之间的字符直接复制给int 变量会是负数,因此要做一下特殊处理: int v = s[j] +256;


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值