//函数功能 : 找元素
//函数参数 : pArray指向数组,len为数组的元素个数
//返回值 : 无
void FindElements_Solution1(int *pArray, int len)
{
if(pArray == NULL || len <= 0 )
return ;
int *pMin = new int[len];
int *pMax = new int[len];
int i;
pMax[0] = pArray[0];
for(i = 1; i < len; i++) //计算自i往前最大值的辅助数组
pMax[i] = (pMax[i-1] >= pArray[i])? pMax[i-1]: pArray[i];
pMin[len-1] = pArray[len-1];
for(i = len - 2; i >= 0; i--) //计算自i开始最小值的辅助数组
pMin[i] = (pMin[i+1] <= pArray[i])? pMin[i+1]: pArray[i];
if(pArray[0] <= pMin[0]) //检查第1个元素是否满足条件
cout<<pArray[0]<<' ';
for(i = 1; i < len - 1; i++)
{
if(pArray[i] >= pMax[i-1] && pArray[i] <=pMin[i+1]) //满足这个关系式的元素符合要求
cout<<pArray[i]<<' ';
}
if(pArray[len-1] >= pMax[len-1]) //检查第len个元素是否满足条件
cout<<pArray[i];
cout<<endl;
delete [] pMin;
delete [] pMax;
pMin = pMax = NULL;
}
void FindElements_Solution2(int *pArray, int len)
{
if(pArray == NULL || len <= 0 )
return ;
int *pMin = new int[len];
int Max;
int i;
Max = pArray[0];
pMin[len-1] = pArray[len-1];
for(i = len - 2; i >= 0; i--) //计算自i开始最小值的辅助数组
pMin[i] = (pMin[i+1] <= pArray[i])? pMin[i+1]: pArray[i];
if(pArray[0] <= pMin[0]) //检查第1个元素是否满足条件
cout<<pArray[0]<<' ';
for(i = 1; i < len - 1; i++)
{
if(pArray[i] >= Max && pArray[i] <=pMin[i+1]) //满足这个关系式的元素符合要求
cout<<pArray[i]<<' ';
Max = (Max < pArray[i])? pArray[i]: Max; //更新当前最大值
}
if(pArray[len-1] >= Max) //检查第len个元素是否满足条件
cout<<pArray[i];
cout<<endl;
delete [] pMin;
pMin = NULL;
}
//函数功能 : 找出数组中两个只出现一次的数字
//函数参数 : arr为源数组,len为数组元素个数,result用来存放结果
//返回值 : 无
void FindIsolateTwo(int *arr, int len, int *result)
{
int i, all = 0, flag = 1;
for(i = 0; i < len ; i++) //所有数异或
all ^= arr[i];
while(!(all&flag)) //寻找过滤位
flag <<= 1;
result[0] = result[1] = 0;
for(i = 0; i < len; i++) //利用过滤位区分
{
if(flag&arr[i])
result[0] ^= arr[i];
else
result[1] ^= arr[i];
}
}
机械节能产品生产企业官网模板...
大气智能家居家具装修装饰类企业通用网站模板...
礼品公司网站模板
宽屏简约大气婚纱摄影影楼模板...
蓝白WAP手机综合医院类整站源码(独立后台)...苏ICP备2024110244号-2 苏公网安备32050702011978号 增值电信业务经营许可证编号:苏B2-20251499 | Copyright 2018 - 2025 源码网商城 (www.ymwmall.com) 版权所有