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++;}elsetimes--;}}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 positionint minProduct = 1; // min negative product at current positionint r = 1; // result, max multiplication totallyfor (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;
}