A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

import java.util.*;
class Halfsearch
{
    public static void main(String[] args)
    {
                char[] arr={'a','b','s','d','e','q','m'};
                sop(arr);
                System.out.println("");
//排序
                for(int x=0;x<arr.length;x++)
                {
                        for(int y=0;y<arr.length-1-x;y++)
                        {
                                int num=new Character(arr[y]).compareTo(new Character(arr[y+1]));
                                if(num>0)
                                        swap(arr,y,y+1);
                        }
                }
                sop(arr);
                System.out.println(getmyIndex(arr,'l'));
    }
        //位置转换
        public static void swap(char[] arr,int s1,int s2)
        {
                char num=arr[s1];
                arr[s1]=arr[s2];
                arr[s2]=num;
        }
        // 打印方法
        public static void sop(char[] arr)
        {
                for(int x=0;x<arr.length;x++)
                {
                    System.out.print(arr[x]+" ");
                }
        }
        //  获取角标方法
        public static int getmyIndex(char[] arr,char key)
        {
                int min=0;
                int max=arr.length-1;
                while(min<max)
                {
                        int mid=(min+max)>>1;
                        int numb=new Character(arr[mid]).compareTo(new Character(key));
                        if(numb>0)
                        {
                                max=mid;
                        }
                        if(numb<0)
                        {
                                min=mid;
                        }
                        return mid;
                }
                return -1-min;
        }
}

评分

参与人数 1技术分 +1 收起 理由
FFF + 1 下次代码要放代码框里哦~

查看全部评分

3 个回复

倒序浏览
import java.util.*;
class Halfsearch
{
    public static void main(String[] args)
    {
                char[] arr={'a','b','s','d','e','q','m'};
                sop(arr);
                System.out.println("");
//排序
                for(int x=0;x<arr.length;x++)
                {
                        for(int y=0;y<arr.length-1-x;y++)
                        {
                                int num=new Character(arr[y]).compareTo(new Character(arr[y+1]));
                                if(num>0)
                                        swap(arr,y,y+1);
                        }
                }
                sop(arr);
                System.out.println(getmyIndex(arr,'m'));
    }
        //位置转换
        public static void swap(char[] arr,int s1,int s2)
        {
                char num=arr[s1];
                arr[s1]=arr[s2];
                arr[s2]=num;
        }
        // 打印方法
        public static void sop(char[] arr)
        {
                for(int x=0;x<arr.length;x++)
                {
                    System.out.print(arr[x]+" ");
                }
        }
        //  获取角标方法
        public static int getmyIndex(char[] arr,char key)
        {
                int min=0;
                int max=arr.length-1;
                while(min<=max)// 此处容易出错哦,如果没有等于号的话,当numb=0的时候,就无法进行else了,直接跳出while循环,最后一个return执行
                {
                        int mid=(min+max)>>1;
                        int numb=new Character(arr[mid]).compareTo(new Character(key));
                        //System.out.println(numb);
                        if(numb>0)
                        {
                                max=mid-1;
                                //System.out.println(max);
                        }
                        else if(numb<0)
                        {
                                min=mid+1;
                                //System.out.println(min);
                        }
                        else return mid;
                }
                return -1-min;
        }
}
回复 使用道具 举报
潜伏 发表于 2013-11-23 22:52
import java.util.*;
class Halfsearch
{

自问自答。搞了一夜完了,哎,人气不旺

点评

FFF
只要努力,我们就会看到。人气旺不旺对努力的人进黑马没有影响!  发表于 2013-11-24 00:27
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马