classSolution{publicbooleanisUnique(String astr){if(astr.length()>26){returnfalse;}//位图的思想,只是用一个int来表示全部int bitMap =0;for(int i =0; i < astr.length(); i++){int x = astr.charAt(i)-'a';//判断其对应位置的二进制位是否为1if(((bitMap>>x)&1)==1){returnfalse;}//如果是0就将这个二进制位修改成1 bitMap |=(1<<x);}returntrue;}}
classSolution{publicintmissingNumber(int[] nums){int ret =0;for(int i =0;i < nums.length;i++){ ret ^= nums[i]^ i;}//最后还有一个其长度没有异或return ret ^ nums.length;}}
题目解析:一个数组中只有一个数字出现一次,其他全部出现三次,找出这个只出现一次的数字 位图思想:一个一个二进制位确定,全部确定最终就得到这个数字 因此每次要计算出其数组每一个数值对应第 i 位 2进制之和,因为其他数字全部出现三次,因此让其 %3,得到的就是要找到数字第i 位 2进制的值
classSolution{publicintsingleNumber(int[] nums){int ret =0;for(int i =0; i <32; i++){int sum =0;//统计其数组第i位2进制之和for(int j =0; j < nums.length; j++){if(((nums[j]>> i)&1)==1){ sum++;}} sum %=3;if(sum ==1){//将其第i位修改成1 ret |=(1<< i);}}return ret;}}
classSolution{publicint[]missingTwo(int[] nums){//先找出消失的两个数字^结果int ret =0;for(int num : nums){ ret ^= num;}for(int i =1;i <= nums.length +2;i++){ ret ^= i;}//此时的ret就是消失的两个数字的异或结果//找出最右边的1 ret = ret ==0? ret : ret&(-ret);//只根据其第i位进行判断即可,因为异或结果是相同为0,不同为1//此时将其分为两类int t1 =0;int t2 =0;for(int num : nums){if((ret & num)!=0){ t1 ^= num;}else{ t2 ^= num;}}for(int i =1;i <= nums.length +2;i++){if((ret & i )!=0){ t1 ^= i;}else{ t2 ^= i;}}returnnewint[]{t1,t2};}}
classSolution{publicint[]missingTwo(int[] nums){//先找出消失的两个数字^结果int ret =0;for(int num : nums){ ret ^= num;}for(int i =1;i <= nums.length +2;i++){ ret ^= i;}//此时的ret就是消失的两个数字的异或结果int d =0;//为1的二进制位while(true){if(((ret>>d)&1)==1){break;} d++;}//只根据其第i位进行判断即可,因为异或结果是相同为0,不同为1//此时将其分为两类int t1 =0;int t2 =0;for(int num : nums){if(((num>>d)&1)==0){ t1 ^= num;}else{ t2 ^= num;}}for(int i =1;i <= nums.length +2;i++){if(((i>>d)&1)==0){ t1 ^= i;}else{ t2 ^= i;}}returnnewint[]{t1,t2};}}