1.数组求和
如果只是普通求和会简单,但是只能使用一行代码该怎么办呢?
int sum(int *a,int n) { return n ==0 ? 0 : sum(a,n-1) + a[n-1]; }
2.寻找发帖水王
int Find(int *a,int n) { int times = 0; int value; for (int i = 0;i < n;++i) { if (times == 0) { value = a[i]; times = 1; } else { if (a[i] == value) { times++; } else times--; } } return value; } int main() { int a[10] = {1,1,1,7,8,1,1,1,2,4}; cout <<Find(a,10) <<endl; return 0; }
3.求最大值和最小值
void arrmax(int *a,int n) { max = 0; min = 0; for (int i = 0;i < n;++i) { if (a[i] >max) { max = a[i]; } if (a[i] < min) { min = a[i]; } } }
4.最大值和次大值
void arrmax(int *a,int n) { max = 0; min = 0; for (int i = 0;i < n;++i) { if (a[i] >max) { max = a[i]; } if (a[i] < min) { min = a[i]; } } }
5.求数组中最短两个元素之间的距离
因为最短距离只可能是相邻元素之间的距离,所以转化为排序问题,时间复杂度O(N*logN);
6.找出两个数组的共同元素
void arrmax(int *a,int *b,int n) { int i = 0; int j = 0; while(i <n && j <n) { if (a[i] < b[j]) { i++; } else if (a[i] == b[j]) { cout << a[i] <<endl; i++; j++; } else { j++; } } } int main() { int a[5] = {0,1,2,3,4}; int b[5] = {1,3,5,7,9}; arrmax(a,b,5); return 0; }
7.找出数组中唯一重复的元素
给定含有1001个元素的数组,其中存放了1-1000之内的整数,只有一个整数是重复的,请找出这个数
先对这个数组进行求和,然后减去1到1000的和。
8.找出出现奇数次的数
给定一个含有n个元素的整型数组a,其中只有一个元素出现奇数次,找出这个元素
因为对于任意一个数k,有k ^ k = 0,k ^ 0 = k,所以将a中所有元素进行异或,那么个数为偶数的元素异或后都变成了0,只留下了个数为奇数的那个元素。
int findOdd(int *a,int n) { int r = a[0]; for (int i = 1;i < n;++i) { r^= a[i]; } return r; } int main() { int a[11] = {1,1,4,3,4,6,8,8,9,3,6}; cout << findOdd(a,11)<<endl; return 0; }
9.找出数组中给定值的数对
有两种情况,一种是经过排序的,一种是没有经过排序的
没有经过排序的需要用一个额外的数组做标记。然后对判断下标进行操作。这里的下标就是数组里的数。
void findSum(int *a,int n,int sum) { int ahead = n -1; int behind = 0; int curSum = 0; while(behind < ahead) { curSum = a[ahead] + a[behind]; if (curSum == sum) { cout << a[ahead] << "," <<a[behind] <<endl; break; } else if (curSum > sum) { ahead--; } else { behind++; } } } int main() { int a[10] = {1,2,4,6,8,9,12,13,15,19}; findSum(a,10,18); return 0; }
10.找出数组最大字段和
int findSum(int *a,int n) { int cur = 0; int sum = 0; for (int i = 0;i < n;++i) { cur = a[i] +cur; if (cur < 0) { cur = 0; } if (cur > sum) { sum = cur; } } return sum; } int main() { int a[8] = {1,-2,3,10,-4,7,2,-5}; cout << findSum(a,8); return 0; } 11.数组最大字段乘积
// 子数组的最大乘积 int MaxProduct(int *a, int n) { int maxProduct = 1; // max positive product at current position int minProduct = 1; // min negative product at current position int r = 1; // result, max multiplication totally for (int i = 0; i < n; i++) { if (a[i] > 0) { maxProduct *= a[i]; minProduct = min(minProduct * a[i], 1); } else if (a[i] == 0) { maxProduct = 1; minProduct = 1; } else // a[i] < 0 { int temp = maxProduct; maxProduct = max(minProduct * a[i], 1); minProduct = temp * a[i]; } r = max(r, maxProduct); } return r; }