消失的数字:
思路1:排序+遍历
1.使用qsort排序数组判断当前数值+1是否是数组下一个元素的数值。
2.如果是一直循环注意数组越界,如果不是那么当前的数组的数值+1就是消失的数。
3.存在0——n的数字是第n个数没有了。循环过程中从头到尾也找不到这个数字。
4.因为在循环过程中数组下标只会从0到n-1.前面排序之后都满足循环要求。
5.在循环判断之前判断一下num[n-1]+1是否等于n;如果等于说明是最大的数值消失直接返回。
6.如果不是进入循环找这个数值。
int cmp(void* a, void* b)
{return (*((int*)a) - *((int*)b));
}int missingNumber(int* nums, int numsSize)
{//排序+遍历的方法qsort(nums, numsSize, sizeof(nums[0]), cmp);int i = 0;int ret = 0;int flag = -1;if ((nums[numsSize - 1] + 1) == numsSize){flag = 0;}//都不是最大数值失去的情况。else{//注意数组越界while (i < numsSize - 1){if ((nums[i] + 1 == nums[i + 1]) && (nums[0] == 0)){i++;}//第一位不是0说明0消失了else if (nums[0] != 0){ret = 0;break;}else{ret = nums[i] + 1;break;}}}if (flag == 0){return numsSize;}return ret;
思路二:使用计算的方法
1.定义sum1和sum2分别作为0到n所有数值的和,和0到n除了消失数字的和。
2.计算sum1直接使用等差数列求和,((0+numsize)*(numsize+1))/2
3.计算sum2直接遍历求和。(防止数组越界)。加numsize次。
int missingNumber(int* nums, int numsSize)
{//计算数值差的方法int sum1=0;int sum2=0;sum2=((0+numsSize)*(numsSize+1))/2;for(int i=0;i<numsSize;i++){sum1+=nums[i];}return sum2-sum1;
}
思路三:按位与的思路
1.定义一个x,先与数组中的每一个内容按位与。
2.然后x再与,0到n的所有数值进行按位与。
3.按位与满足交换律(相同的数消除)
比如:0,1,2,3,4,5
: 0,1,2,3,4,5,6
按位与之后结果是6.
int missingNumber(int* nums, int numsSize)
{int x=0;for(int i=0;i<numsSize;i++){x^=nums[i];}for(int i=0;i<=numsSize;i++){x^=i;}return x;
数字在升序数组中出现的次数
数字在升序数组中出现的次数
思路1:
1.这个K只出现一次,或者出现多次。
2.这个K没有出现过。
3.二分查找的思路。
4.当查找结束,判断arr[mid]==k吗?,不等于说明这个k不存在于这个数组里面我们直接返回0;
5.找到了这个K数的位置我们mid下标向右移动直到下一个不是停止到k的位置停止,左边同理。
6.同时记录K的数值。
int GetNumberOfK(int* nums, int numsLen, int k)
{// write code hereif (numsLen == 0){return 0;}//出现一次(mid这个位置确实是出现了一次)and没有出现int left = 0;int right = numsLen - 1;int mid = 0;while (left <= right){mid = (left + right) / 2;if (nums[mid] < k){left = mid + 1;}else if (nums[mid] > k){right = mid - 1;}else{break;}}//这个数值不存在if (nums[mid] != k){return 0;}//只有一个数,这一个就是要的int count = 1;if (nums[mid] == k && numsLen == 1){return 1;}else if(nums[mid] == k && numsLen != 1){int left=mid;int right=mid;while (nums[right + 1] == k){right++;count++;}while (nums[left - 1] == k){left--;count++;} }return count;
}
整数转换
思路1:
1.注意A,B的范围。在二进制位上31个是数值位,一位是符号位。
2.我们可以通过按位异或的方式拿出不同位数的情况。
3.变成了记录按位异或结果中1的数值个数。
4.b=1<<i 判断异或结果&b是否==b相等就说明对应异或结果处的值为1.
5.A,B 。有三种情况:
1.A,B中有一个为负数,所以需要加上符号位的1.
2.A,B同正或者同负,直接返回统计的结果。
int convertInteger(int A, int B){//两个数值进行按位异或int C=A^B;//进行记录int count=0;int b=0;if(((A<0)||(B<0))){count+=1;}for(int i=0;i<31;i++){b=(1<<i);if((b&C)==b){count++;}}if((A<0)&&(B<0))count--;return count;}