java题目

package com.test;

import java.util.Arrays;

import com.sun.xml.internal.bind.v2.runtime.unmarshaller.XsiNilLoader.Array;

public class Sort
{
    /**
     * 根据以下要求,比较两个字符串的大小,并返回比较结果:
     * 1、比较两字符串的大小。 2、忽视大小写
     *  3、 按字典序 如果第一个字符串大于第二个字符串 返回大于0,
     * 如果第一个字符串等于第二个字符串 返回等于0
     * ,如果第一个字符串小于第二个字符串返回小于0。
     * 4、例子 compareToIgnoreCase(“HARD”,”hark”)的比较结果返回小于0 。
     *
     * @param str1
     * @param str2
     * @return
     * @see [类、类#方法、类#成员]
     */
    public static int  sortArray(String str1, String str2)
    {
       String str1Temp = str1.toLowerCase();
       String str2Temp = str2.toLowerCase();

       if(str1.compareToIgnoreCase(str2) > 0)
       {
           return 1;
       }else if(str1.compareToIgnoreCase(str2) < 0)
       {
           return -1;
       }else
       {
           return 0;
       }

    }

    /**
     * 把数组中的1-26的数字映射成a-z的小写字母 如果输入其他数字,则在页面上打印"?"
     * 如:int [] arr={1,2,3,4,30} 输出:a,b,c,d,?
     *
     * @param a
     * @return
     * @see [类、类#方法、类#成员]
     */
    public static String conver(int[] a)
    {
        String goal = "";
        for(int i= 0; i < a.length;i++)
        {
            if(a[i] > 26 || a[i] <1)
            {
                goal = goal +"?,";
            }
            else
            {
                int temp = a[i]+'a'-1;
                char str = (char)(temp);
                goal = goal+str+",";
            }
        }
        return goal.substring(0, goal.length()-1);
    }

    /**
     * 输入A-Z26个字母,输入一个大写字母后,输出该字母之后第5个字母的小写。
     *  如输入A,输出f…… 输入Z,则输出e。 超出Z时,超过1个,
     *  则返回a,超过两个,则返回b,以此类推。
     */
    public static char converTochar(char chars)
    {
        if (chars >= 'A' && chars <= 'Z')
        {
            if ((chars + 5) > 90)
            {
                return (char)(chars - 85 + 'a' - 1);
            }
            else
            {
                return (char)(chars + 37);
            }

        }    
            return chars;
    }

    /**
     * 判断一个字符串是否是首字母大写,其余字母都是小写。
     *  例如 输入:True 输出: true
     */



    /**
     * 给一个二维数组inArr[ ][ ],写一个方法获取每一列的最小值,输出到一个一维数组outArr[ ]中。
     *  如:inArr[ ][ ]={{1,8,3},{6,5}},则输出outArr[ ] = {1,5,3}
     */
    public static int[] findMin(int[][] inArr)
    {
        int maxLength = 0;
        for (int i = 0; i < inArr.length; i++)
        {
            if (inArr[i].length > maxLength)
            {
                maxLength = inArr[i].length;
            }
        }
        int[] outArr = new int[maxLength];
        for (int column = 0; column < maxLength; column++)
        {
            outArr[column] = Integer.MAX_VALUE;
            for (int row = 0; row < inArr.length; row++)
            {
                if (column < inArr[row].length)
                {
                    if (inArr[row][column] < outArr[column])
                    {
                        outArr[column] = inArr[row][column];
                    }
                }
            }
        }
        return outArr;
    }

    /**
     * 实现数组倒置算法: 如一数组:1,2,3 4,5,6 则倒置后:1,4 2,5 3,6
     */
    public static int[][] goal(int[][] arrays)
    {
        int[][] goal = new int[arrays[0].length][arrays.length];
        for (int i = 0; i < arrays.length; i++)
        {
            for (int j = 0; j < arrays[0].length; j++)
            {
                goal[j][i] = arrays[i][j];
            }
        }
        return goal;
    }
    /**
     * 输入一个字符串,字符串是字母和数字的组合,编程实现输出一个新的字符串,
     * 要求字母在前面,
     * 数字在后面,顺序不变,例如:2s7ess83a 变成sessa2783
     */
    public static String splits(String str)
    {
        String strings = "";
        String numbers ="";
        for(int i = 0;i < str.length();i++)
        {
            if((str.charAt(i)>= 'A' && str.charAt(i) <='Z')||
                (str.charAt(i)>= 'a' && str.charAt(i) <='z'))
            {
                strings = strings + str.charAt(i);
            }else
            {
                numbers = numbers +str.charAt(i);
            }
        }
        return strings+numbers;
    }
   /**
    * 一个字符串,获取最长的一个单词,如有多个相同长度的单词返回第一个单词。
    * 入输入:“hello china”则返回 hello
    */
    public static String getString(String str)
    {
        String[] strings = str.split(" ");
        String tempMaxLenth = strings[0];
        for(int i = 1;i < strings.length;i++)
        {
            if(tempMaxLenth.length() < strings[i].length())
            {
                tempMaxLenth = strings[i];
            }
        }
        return tempMaxLenth;

    }
/**
 * 回文
 *
 */

    public static int huiwen(int str[])
    {
    int i,len,k=1;
    len=str.length;
   // len=str.len(str);
    for(i=0;i     {
    if(str[i]!=str[len-i-1])
    {
    k=0;
    break;
    }
    }
    if(k==0)
   System.out.println(Arrays.toString(str) +"不是一个回文数");
    else
        System.out.println(Arrays.toString(str)+"是一个回文数");
    return 0;
    }


/**
 * 输入一个字符串,字符串是字母和数字的组合,编程实现输出一个新的字符串,
 * 要求字母在前面,数字在后面,顺序不变,例如:2s7ess83a 变成sessa2783
 */

    public static String getString(String a)
    {
        StringBuffer sb1 = new StringBuffer();
        StringBuffer sb2 = new StringBuffer();

        char arr[] = a.toCharArray();

        for (int i = 0; i < arr.length; i++)
        {
            int temp = Integer.valueOf(arr[i]);

            if ('0' <= temp && temp <= '9')
            {
                sb2.append(arr[i]);
            }
            else
            {
                sb1.append(arr[i]);
            }
        }

        return sb1.append(sb2).toString();
    }


    /**
     *将一个字符里出现最多的字母截取,如,addcbbs变为acs。
     */

方法1:
   public static void main(String args[])
    {
    String str="213sdf452346dfhb";

    String temp=“”;

char[] c=str.toCharArray();

    for(int i=0; i     {
        if(temp.indexOf(c[i])==-1)
        {
        temp+=c[i];
        
        }
    }
    System.out.println("去重后的字符窜为:"+temp);
    }
    

方法2:
    public static String splits(String str)
        {
            String strings = "";
            String numbers = "";
            for (int i = 0; i < str.length(); i++)
            {
                if ((str.charAt(i) >= 'A' && str.charAt(i) <= 'Z') ||
                    (str.charAt(i) >= 'a' && str.charAt(i) <= 'z'))
                {
                    strings = strings + str.charAt(i);
                }
                else
                {
                    numbers = numbers + str.charAt(i);
                }
            }
            return strings + numbers;
        }

        public static String subStrings(String str)
        {
            String goals = "";
            Set set = new HashSet();
            List goalList = new ArrayList();
            for (int i = 0; i < str.length(); i++)
            {
                set.add(str.charAt(i) + "");
                goalList.add(str.charAt(i)+"");
            }
            // String[] goal = (String[])set.toArray();
            String[] goal = (String[])set.toArray(new String[0]);
            // char[] goalt = (char[])set.toArray();//(new char[0]);
            int[] count = new int[goal.length];


            for (int i = 0; i < goal.length; i++)
            {
                int tempCount = 0;
                for (int j = 0; j < str.length(); j++)
                {
                    if (goal[i].equals(str.charAt(j)+""))
                    {
                        tempCount++;
                    }
                }
                count[i] = tempCount;
            }
            int countMax = count[0];
            List MaxCount = new ArrayList();
            for (int i = 1; i < count.length; i++)
            {
                if (count[i] > countMax)
                {
                    countMax = count[i];
                }
            }

            List goalListRemove = new ArrayList();
            for (int i = 0; i < count.length; i++)
            {
                if (count[i] == countMax)
                {
                    goalListRemove.add(goal[i]);
                    MaxCount.add(i);
                }
            }

            for (Iterator it = goalList.iterator(); it.hasNext();)
            {
                String a = (String)it.next();

                if(goalListRemove.contains(a))
                {
                    it.remove();
                }
            }


            return goalList.toString();
        }




   //c[i]= a[i]+b[b.lenght()-i-1];
    public static void main(String args[])
    {

//        int [] arr={1,2,3,4,30,8};
//        Arrays.sort(arr);
//        System.out.print(Arrays.toString(arr));
//
//
//        char temp = 'A';
//       System.out.println(Sort.isHope("TruE"));
//
//       System.out.println(Arrays.deepToString(Sort.goal(arrays)));

        charstr[] a="12345654321";
        a.
    }
}


你可能感兴趣的:(字符窜操作,java字符窜操作)