查找数问题
来源:互联网 发布:猎豹免费wifi软件 编辑:程序博客网 时间:2024/06/18 12:49
1. 一个数组中,只有两个数出现一次,其他都出现两次,找出这两个出现一次的数.(异或的运用和位操作)
int get_xor_result(int a[],int length){ int tem = 0; for(int i =0; i<length; i++) { tem ^= a[i]; } return tem;}int get_pos(int tem){ for(int i = 0; i<32; i++) { if(tem & 1 == 1) return i; tem >>= 1; } return 0;}int get_num(int a[],int length,int *num1,int *num2){ int result,pos; result = get_xor_result(a,length); pos = get_pos(result); *num1 = *num2 = 0; for(int i=0; i<length; i++) { if((a[i]>>pos & 1) == 1) *num1 ^= a[i]; else *num2 ^= a[i]; } return 0;}int main(void){ int a[10]={1,2,3,4,5,6,4,3,2,1}; int num1,num2; get_num(a,10,&num1,&num2); printf("%d,%d\n",num1,num2); printf("hello world\n"); return 0;}
2.一个大数组中只有两个数有重复的,其他都是出现一次,找出是哪两个数?
#include <stdio.h>#define LENGTH 10static char array[LENGTH / 8 + 1];void get_num(int a[], int length, int *num1, int *num2){int tem = 0;*num1 = *num2 = 0;for (int i = 0; i < length; i++){tem = (array[a[i] / 8] >> (a[i] % 8)) & 1;if (tem != 1)array[a[i] / 8] |= 1 << a[i] % 8;else{if (*num1 == *num2)*num1 = a[i];else*num2 = a[i];}}}int main(){int num1, num2;int a[LENGTH] = { 1, 2, 11, 4, 11, 5, 6, 6, 7, 8 };get_num(a, LENGTH, &num1, &num2);printf("%d,%d\n", num1, num2);printf("hello world\n");return 0;}
0 0
- 查找数问题
- 查找给定数对扩充问题
- 面试题实现--(百度的不存在数查找问题)
- 查找问题整理(2)查找第K大的数Kth Order Statitic
- 查找最大数
- 查找相同数个数
- 有序数折半查找
- 二叉查找数
- 查找缺失的数
- 查找重复的数
- 二叉查找数
- 二分法查找数
- 20151015查找水仙花数
- 二分法查找某数
- 字典数查找字串
- 二维数组查找数
- 查找次最大数
- 完数查找
- UVA10603
- Snail—Hibernate之初识配置
- Objective-C 中的 @property和@synthesize
- 常用的android弹出对话框
- 今年苏州的天气很好
- 查找数问题
- STL迭代器简介
- hdu 4960 Another OCD Patient(记忆化)
- 数据库结果集ResultSet详解
- AVL树的旋转,插入,删除操作
- HDU 4969 Just a Joke(积分)
- Python字符串部分习题
- 二叉树的遍历
- C++中构造函数能调用虚函数吗?