/* * 卿°ç»A[0..n-1]ä¸ï¼ææè°çéæ¯ç´¢å¼ï¼æ»¡è¶³æ¡ä»¶A[i]=iãç»å®ä¸ä¸ªååºæ°ç»ï¼ * å ç´ å¼åä¸ç¸åï¼ç¼åä¸ä¸ªæ¹æ³ï¼å¤æå¨æ°ç»A䏿¯å¦åå¨éæ¯ç´¢å¼ã请æèä¸ç§ * å¤æåº¦ä¼äºo(n)çæ¹æ³ãç»å®ä¸ä¸ªintæ°ç»Aåint n代表æ°ç»å¤§å°ï¼è¯·è¿åä¸ä¸ª * boolï¼ä»£è¡¨æ¯å¦åå¨éæ¯ç´¢å¼ãæµè¯æ ·ä¾ï¼ * [1,2,3,4,5] * è¿åï¼false */ public class MagicIndex { public boolean findMagicIndex(int[] A, int n) { // write code here return find(A,0,n-1); } private boolean find(int[] A, int begin,int end) { if(begin>end) return false; int index=(begin+end)/2; if(A[index]==index) return true; if(index>A[index]) return find(A,index+1,end); else return find(A,begin,index-1); } }