1648.统计一致字符串的数目

1 暴力遍历

func countConsistentStrings(allowed string, words []string) int {
	ans := 0
	m := make(map[int32]struct{}, len(allowed))
	for _, v := range allowed {
		m[v] = struct{}{}
	}

	for _, word := range words {
		contain := true
		for _, v := range word {
			if _, ok := m[v]; !ok {
				contain = false
				break
			}
		}
		if contain {
			ans++
		}
	}
	return ans
}

通过map记录目标字符串的每个字符,再循环words中每个字符串是否都存在与allowed中。时间复杂度为取决于words数组。

2.使用位运算
| 或运算 :有1为1,全0为0

使用一个32位整型变量足以表示26个英文字母,通过|或运算表示字母是否出现过
mark代表allowed出现的字母,mark代表word中出现的字母。最后通过mark1|mark判断mark1中出现的字母是否都在mark中。

func countConsistentStrings(allowed string, words []string) int {
	ans := 0
	// mark记录allowed中出现的字母
	mark := 0
	for _,c := range allowed {
		mark|= 1 << (c-'a')
	}

	for _,word := range words {
		mark1 := 0
		for _,c1 := range word {
			mark1 |= 1 << (c1-'a')
		}
		if mark1|mark == mark {
			ans++
		}
	}
	return ans
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值