JavaSE编码试题强化练习5

Posted 我有两个皮夹克

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了JavaSE编码试题强化练习5相关的知识,希望对你有一定的参考价值。

1.不使用函数实现字符串的翻转
/**
 * 1.不使用函数实现字符串的翻转
 */
public class TestStringReverse {
  public static void main(String[] args) {
    String s1 = "FEDCBA";
    System.out.println("翻转前:"+s1);
    /**
     * 此处需注意用s1接收方法的返回值,不然输出的还是没翻转之前的s1
     */
    s1 = reverseI(s1);
    System.out.println("方法I翻转后:"+s1);
    s1 = reverseII(reverseII(s1));
    System.out.println("方法II翻转后:"+s1);
  }

  /**
   * 方法I
   */
  public static String reverseI(String str){
    /**
     * 实现思路:将字符串存入一个字符数组中,首尾交换,每交换一次起始位置+1,结束位置-1
     * 调用toCharArray()方法,返回一个字符数组,方便通过下标取放字符,最终实现字符串的翻转
     */
    char[] ch = str.toCharArray();
    /**
     * 定义起始和结束位置下标索引号
     */
    int start = 0;
    int end = ch.length - 1;
    char temp;
    while (start < end){
      temp = ch[start];
      ch[start] = ch[end];
      ch[end] = temp;
      start++;
      end--;
    }
    /**
     * public String(char value[]) 此方法实现传入一个字符数组,返回一个字符串
     */
    String str0 = new String(ch);
    return str0;
  }

  /**
   * 方法II
   */
  public static String reverseII(String str){
    /**
     * 调用toCharArray()方法,返回一个字符数组,方便通过下标取放字符,最终实现字符串的翻转
     */
    char[] ch = str.toCharArray();
    /**
     * 定义一个空字符串
     */
    String str0 = "";
    for (int i = 0; i < ch.length; i++) {
      /**
       * 此法 str0 = temp + str0 中temp和str0的顺序是不能调换的,这是关键
       */
      char temp = ch[i];
      str0 = temp + str0;
    }
    return str0;
  }
}

运行结果:

 

 2.给定一个字符串,如"yekmaakkccekymbvb",求字符串中有多少种字符以及每个字符的个数;把结果写入E盘名为Testiostream.txt的文本文件中;读出刚才写入TestIOStream.txt文本文件的内容。

public class TestIOStream {
  public static void main(String[] args) {
    String str = "yekmaakkccekymbvb";
    Map<String,Integer> map = count(str);
    write(map);
    read();
  }
  /**
   * 求字符串中有多少种字符及每个字符的个数
   */
  public static Map<String,Integer> count(String s){
    Map<String,Integer> map = new LinkedHashMap<String,Integer>();
    for (int i = 0;i < s.length();i++){
      /**
       * public String substring(int beginIndex, int endIndex) 截取字符串中的子串
       * (前闭后开)
       * substring(i,i + 1)每次截取一个字符
       * 定义一个key接收返回的子串
       */
      String key = s.substring(i,i + 1);
      /**
       * 定一个整型value接收map.get(key)返回的值
       */
      Integer value = map.get(key);
      /**
       * 判断value若为空,即
       */
      if (value == null){
        map.put(key,1);
      }else {
        map.put(key,value+1);
      }
    }
    return map;
  }
  /**
   * 把结果写入E盘名为TestIOStream.txt的文件夹中
   */
  public static void write(Map<String,Integer> map){
    PrintWriter pw = null;
    try {
      pw = new PrintWriter("e:/TestIOStream.txt");
      pw.println("size:"+map.size());
      Set<Map.Entry<String,Integer>> entrySet = map.entrySet();
      for (Map.Entry entry : entrySet){
        pw.println(entry.getKey()+":"+entry.getValue());
      }
    } catch (FileNotFoundException e) {
      e.printStackTrace();
    }finally {
      pw.close();
    }
  }
  /**
   * 读出刚才写入的文本文件的内容
   */
  public static void read(){
    BufferedReader br = null;
    try {
      br = new BufferedReader(new FileReader("e:/TestIOStream.txt"));
      String str = null;
      do {
        str = br.readLine();
        System.out.println(str);
      }while (str != null);
    } catch (FileNotFoundException e) {
      e.printStackTrace();
    } catch (IOException e) {
      e.printStackTrace();
    }finally {
      try {
        br.close();
      } catch (IOException e) {
        e.printStackTrace();
      }
    }
  }
}

运行结果:

 

 

 

 3.使用冒泡排序对一个int数组进行排序。

public class TestBubbleSort {
  public static void main(String[] args) {
    int [] arr = {9,7,6,4,3,1,0};
    //int [] arr = {1,2,3,4,5,6,7};
    System.out.println("排序前:"+Arrays.toString(arr));
    bubbleSort(arr);
    System.out.println("排序后:"+Arrays.toString(arr));
  }
  public static void bubbleSort(int [] arr){
    for (int i = 0;i < arr.length - 1;i++){
      boolean flag = false;
      for (int j = 0;j < arr.length - 1 - i;j++){
        if (arr[j] > arr[j + 1]){
          int temp = arr[j + 1];
          arr[j + 1] = arr[j];
          arr[j] = temp;
          flag = true;
        }
      }
      if (!flag){
        break;
      }
    }
  }
}

运行结果:

以上是关于JavaSE编码试题强化练习5的主要内容,如果未能解决你的问题,请参考以下文章

JavaSE编码试题强化练习2

JavaSE编码试题强化练习4

01 变量与数据类型

试题 基础练习 01字串--c++代码

试题 基础练习 01字串--c++代码

试题 基础练习 Huffuman树--蓝桥杯c++