百度面试题:求一个已排序的数组中绝对值最小的元素

简介:
题目为:

有一个已经排序的数组(升序),数组中可能有正数、负数或0,求数组中元素的绝对值最小的数,要求,不能用顺序比较的方法(复杂度需要小于O(n)),可以使用任何语言实现

例如,数组{-20,-13,-4, 6, 77,200} ,绝对值最小的是-4。

这一题该如何求呢?

初步的解决思路是:

    1.数组中的元素全为正,取最左边的数字;

    2.数组中的元素全为负,取最右边的数字的绝对值;

    3.数组中有正数有负数,就用二分法查找,判断中间元素的符号

       a)中间元素为正,继续判断中间元素前面一个元素的符号

       b)中间元素为负,判断中间元素后一个元素的符号

       c)中间元素为零,令其等于结果值返回

下面是根据上面的想法的代码实现,应该还会有漏洞

#include "stdafx.h"
#include <iostream>

using namespace std;

//求取数组中绝对值最小的数字
int minAbsolute(int arr[],int size);
//返回两个数中较小的数
int compare(int a,int b);
int _tmain(int argc, _TCHAR* argv[])
{
	int a[10] = {-10,-8,-5,-3,2,5,8,9,11,15};	
	int size = sizeof(a)/sizeof(int);
	int result = minAbsolute(a,size);
	cout<<"绝对值最小的数是:"<<result<<endl;
	return 0;
}

int minAbsolute(int arr[],int size)
{
	int first,last,mid;	
	first = 0;
	last = size - 1;
	int result;

	//数组中的数全是负数,取最右边的数
	if (arr[0] < 0 && arr[size-1] < 0)
	{
		result = arr[size-1];
	} 
	//数组中的数全是正数,取最左边的数
	else if (arr[0] > 0 && arr[size-1] > 0)
	{
		result = arr[0];
	}
	//数组有正有负,二分查找
	else
	{
		while(first < last)
		{
			int mid = (first + last)/2;
			if (arr[mid] > 0)
			{
				if (arr[mid - 1] > 0)
				{
					last = mid - 1;
				} 
				else if(arr[mid - 1] < 0)
				{
					result = compare(-arr[mid - 1],arr[mid]);
					break;
				}
				else
				{
					result = arr[mid - 1];
					break;
				}
			}
			else if (arr[mid] < 0)
			{
				if (arr[mid + 1] < 0)
				{
					first = mid + 1;
				} 
				else if (arr[mid + 1] > 0)
				{
					result = compare(-arr[mid],arr[mid+1]);
					break;
				} 
				else
				{
					result = arr[mid + 1];
					break;
				}				
			} 
			else
			{
				result = arr[mid];
				break;
			}
		}
	}
	return result;
}

int compare(int a,int b)
{
	if (a > b)
	{
		return b;
	} 
	else
	{
		return a;
	}
}


相关文章
|
12月前
|
算法 前端开发 Java
数据结构与算法学习四:单链表面试题,新浪、腾讯【有难度】、百度面试题
这篇文章总结了单链表的常见面试题,并提供了详细的问题分析、思路分析以及Java代码实现,包括求单链表中有效节点的个数、查找单链表中的倒数第k个节点、单链表的反转以及从尾到头打印单链表等题目。
131 1
数据结构与算法学习四:单链表面试题,新浪、腾讯【有难度】、百度面试题
|
Java
Java 基础语法-面试题(54-63道)(数组+类+包)
Java 基础语法-面试题(54-63道)(数组+类+包)
89 16
|
C语言
【Amazon 面试题1】一个数组,里面得数出现的次数是偶数次,只有一个数出现的次数是奇数次,找出那个出现奇数次的数
本文介绍了解决Amazon面试题的一种方法,即在一个所有数字出现次数都是偶数,除了一个数字出现奇数次的数组中,利用异或运算的性质找出出现奇数次的数字,并提供了C语言实现的代码示例。
172 1
|
Python
【面试题解答】一个有序数组 nums ,原地删除重复出现的元素
【面试题解答】一个有序数组 nums ,原地删除重复出现的元素
119 0
|
存储 算法 数据可视化
【模拟面试问答】深入解析力扣164题:最大间距(桶排序与排序方法详解)
【模拟面试问答】深入解析力扣164题:最大间距(桶排序与排序方法详解)
|
数据库
面试题ES问题之Elasticsearch的排序分页和高亮功能如何解决
面试题ES问题之Elasticsearch的排序分页和高亮功能如何解决
143 0
|
存储 算法
经典的滑动窗口的题目 力扣 2799. 统计完全子数组的数目(面试题)
经典的滑动窗口的题目 力扣 2799. 统计完全子数组的数目(面试题)
142 0
|
开发框架 .NET
技术好文共享:面试题:找出数组中只出现一次的2个数(异或的巧妙应用)(出现3次)
技术好文共享:面试题:找出数组中只出现一次的2个数(异或的巧妙应用)(出现3次)
|
存储 算法 搜索推荐
深入解析力扣179题:最大数(自定义排序法详解及模拟面试问答)
深入解析力扣179题:最大数(自定义排序法详解及模拟面试问答)
|
存储 SQL 算法
LeetCode 83题:删除排序链表中的重复元素【面试】
LeetCode 83题:删除排序链表中的重复元素【面试】