给你两个整数,n 和 start 。
数组 nums 定义为:nums[i] = start + 2*i(下标从 0 开始)且 n == nums.length 。
请返回 nums 中所有元素按位异或(XOR)后得到的结果。
- #方法一:位运算
- def xorOperation(n,start):
- res=0
- for i in range(n):
- res^=(start+2*i) #逐个异或
- return res
给你一个由不同字符组成的字符串 allowed 和一个字符串数组 words 。如果一个字符串的每一个字符都在 allowed 中,就称这个字符串是 一致字符串 。
请你返回 words 数组中 一致字符串 的数目。
- #方法一:位运算
- def countConsistentStrings(allowed,words):
- target=0
- for a in allowed:
- target|=1<<ord(a)-ord('a') #用三十二位数存储出现的字母例如ab 11 abd 1011
- res=0
- for w in words:
- tem=0
- for i in w:
- tem|=1<<ord(i)-ord('a') #左移 如1<<2 100
- res+=(target|tem) ==target #看看或后等不等于目标值,如1011 | 1010==1011
- return res