C语言输出旋转后数组中的最小数元素的算法原理与实例
问题描述:把一个数组最开始的若干个元素搬到数组的末尾,我们称之为数组的旋转。输入一个排好序的数组的一个旋转,输出旋转数组的最小元素。例如数组{3,4,5,1,2}为{1,2,3,5}的一个旋转,该数组的最小值为1。 //{1,6,7,8,9,10} 1 //{4,10,3} 1 //{1,1} 1 //{1,1} 1 //{9,9} 9 错误 //函数功能 : 旋转数组的最小元素 //函数参数 : pArray指向数组,len为数组长度 //返回值 : 最小元素 int FindMin(int *pArray,int len) { if(pArray == NULL || len <= 0) return 0; int left = 0,right = len - 1,mid; while(right - left != 1) { mid = left + ((right - left)>>1); if(pArray[right] >= pArray[mid]) right = mid; else if(pArray[left] <= pArray[mid]) left = mid; } return pArray[right] > pArray[left] ? pArray[left]: pArray[right]; } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |