判断字符串 b 的所有字符是否都再字符串 a 中出现过

判断字符串 b 的所有字符是否都再字符串 a 中出现过,a,b都是可能包含汉字的字符串。b中重复出现的汉字,那么a中也要至少出现相同的次数。

汉字使用gbk编码(简单的所,用两个字节表示一个汉字,高字节最高位为1的代表汉字,低字节最高位可以不为1)。

int is_include(char *a  ,  char *b)

返回0 表示没有都出现过,返回1表示都出现过。


我的解法:

 

将字符串a建树(如avl树),每个结点是一个字符,重复的统计计数。

 

将b中的字符依次插入,如果插入失败(树中有此结点)则计数减1;

 

如果插入成功,说明b中出现了a中没有的字符,返回0;

 

注意对汉字的判断即可。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值