JavaSE编码试题强化练习6

1.写出选择排序的代码实现,对一个int数组进行排序
public class TestSelectSort {
  public static void main(String[] args) {
    int [] arr = {87,65,5,5,43,21};
    System.out.print("排序前:[ ");
    for (int i : arr){
      System.out.print(i+" ");
    }
    System.out.println("]");
    selectSort(arr);
    System.out.print("排序后:[ ");
    for (int i : arr){
      System.out.print(i+" ");
    }
    System.out.println("]");
  }
  public static void selectSort(int[] arr){
    for (int i = 0;i < arr.length - 1;i++){
      int minIndex = i;
      for (int j = i;j < arr.length - 1;j++){
        if (arr[minIndex] > arr[j + 1]){
          minIndex = j + 1;
        }
      }
      if (minIndex != i){
        int temp = arr[minIndex];
        arr[minIndex] = arr[i];
        arr[i] = temp;
      }
    }
  }
}

运行结果:

2.使用IO包中的类读取E盘上exam.txt文本文件的内容,每次读取一行内容,将每行作为一个输入放入ArrayList的泛型集合中并将集合中的内容使用加强for进行输出显示。

public class TestReader {
  public static void main(String[] args) {
    String path = "E:/exam.txt";
    outputMethod(path);
  }

  private static void outputMethod(String path) {
    /**
     * 创建集合对象
     */
    List<String> list = new ArrayList<String>();
    /**
     * 创建缓冲区对象
     */
    BufferedReader br= null;
    try {
      br = new BufferedReader(new FileReader(path));
      /**
       * 读取数据每次读取一行
       */
      String line = br.readLine();
      while (line != null){
        list.add(line);
        line = br.readLine();
      }
    } catch (FileNotFoundException e) {
      e.printStackTrace();
    } catch (IOException e) {
      e.printStackTrace();
    }finally {
      try {
        if (br != null){
          br.close();
        }
      } catch (IOException e) {
        e.printStackTrace();
      }
      for (String s : list){
        System.out.println(s);
      }
    }
  }
}

文本内容:

程序运行结果:

注意:文本内容要以UTF-8格式保存,不然程序读取时会报乱码,如下图(文本以ANSI格式保存的):

3.编写两个线程,一个线程打印1-52的整数,另一个线程打印字母A-Z。打印顺序为12A34B56C….5152Z。即按照整数和字母的顺序从小到大打印,并且每打印两个整数后,打印一个字母,交替循环打印,直到打印到整数52和字母Z结束。

/**
 * 打印类
 */
public class Printer {
  /**
   * 设为1,方便计算3的倍数
   */
  private int index = 1;

  /**
   * 打印数字的方法,每打印两个数字,等待打印一个字母
   */
  public synchronized void print(int i){
    while (index % 3 == 0){
      try {
        wait();
      } catch (InterruptedException e) {
        e.printStackTrace();
      }
    }
    System.out.print(""+i);
    index++;
    notifyAll();
  }
  /**
   * 打印字母,每打印一个字母等待打印两个数字
   */
  public synchronized void print(char c){
    while (index % 3 != 0){
      try {
        wait();
      } catch (InterruptedException e) {
        e.printStackTrace();
      }
    }
    System.out.print(""+c);
    index++;
    notifyAll();
  }
}
/**
 * 打印数字线程
 */
public class NumberPrinter extends Thread {
  private Printer p;

  public NumberPrinter(Printer p) {
    this.p = p;
  }

  public void run() {
    for (int i =1;i <= 52;i++){
      p.print(i);
    }
  }
}
/**
 * 打印字母线程
 */
public class LetterPrinter extends Thread {
  private Printer p;
  public LetterPrinter(Printer p){
    this.p = p;
  }
  public void run(){
    for (char c = ‘A‘;c <= ‘Z‘;c++){
      p.print(c);
    }
  }
}
public class TestThread {
  public static void main(String[] args) {
    /**
     * 创建打印机对象
     */
    Printer p = new Printer();
    /**
     * 创建线程对象并启动线程
     */
    Thread t1 = new NumberPrinter(p);
    Thread t2 = new LetterPrinter(p);
    t1.start();
    t2.start();
  }
}

运行结果:

原文地址:https://www.cnblogs.com/sinoaccer/p/11965194.html

时间: 2024-10-11 11:37:19

JavaSE编码试题强化练习6的相关文章

JavaSE编码试题强化练习2

1.编写递归算法程序:一列数的规则如下: 0.1.1.2.3.5.8.13.21.34...... 求数列的第40位数是多少. public class TestRecursion { public static void main(String[] args) { /** * 调用fibo方法并输出结果 */ int n = 40; TestRecursion tr = new TestRecursion(); System.out.println(tr.fibo(n)); } /** * 定

JavaSE编码试题强化练习4

1.编写一个Worker类,为Worker类添加相应的代码,使得Worker对象能正确放入TreeSet中.并编写相应的测试代码. /** * Worker类 */ public class Worker implements Comparable<Worker>{ /** * 私有属性 */ private String name; private int age; private double salary; /** * 构造方法 */ public Worker() { } public

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

字符集与字符编码的强化理解与操作实践

字符集与字符编码的强化理解与操作实践 踩坑 最近在工作中遇到了一个说大不大说小不小的问题,就是当我解析一个xml文件的时候,抛出了一个"Invalid byte 2 of 2-byte UTF-8 sequence"的异常,这个异常会导致解析直接退出,显然不能容忍.查阅相关资料稍微定位了一下,大概知道是字符集的问题,仔细一看,xml文件中的确有中文字符,而且当我把这些中文字符删了之后的确又能解析成功.不过我还是不能理解这当中的缘由,不过由于时间原因,当时只是把中文字符删了就草草完工.现

JavaSE 面试题: 方法的参数传递机制

JavaSE 面试题 方法的参数传递机制 import java.util.Arrays; public class Test { public static void main(String[] args) { int i = 1; String str = "hello"; Integer num = 200; int[] arr = {1, 2, 3, 4, 5}; MyData my = new MyData(); change(i, str, num, arr, my); S

JavaSE 笔试题: 自增变量

JavaSE 笔试题 自增变量 public class Test { public static void main(String[] args) { int i = 1; i = i++; int j = i++; int k = i + ++i * i++; System.out.println("i=" + i); System.out.println("j=" + j); System.out.println("k=" + k); }

javaSE面试题总结

目 录 第一章 初识Java 1 1. Java跨平台原理(字节码文件.虚拟机) 1 2. Java的安全性 1 3. Java三大版本 2 4. Java开发运行过程 2 5. Java开发环境配置 2 6. 什么是JVM?什么是JDK? 什么是JRE? 2 7. Java三种注释类型 3 第二章 数据类型和运算符 4 1. 8种基本数据类型及其字节数 4 2. i++和++i的异同之处 4 3. &和&&的区别和联系,|和||的区别和联系 5 4. 用最有效率的方法算出2乘以8

JAVASE面试题

1.抽象类和接口的区别 抽象类重在对象的本质,接口则是对象的附加行为 抽象类是按需实现 ,接口必须全部实现 一个类只能继承一个抽象类 ,但是能多实现接口 抽象类中能定义普通的方法 ,接口中不能定义普通的方法 应用的场景 : 抽象类: 在设计类时,如果有些方法我们能确定,而有些方法不能确定,这时候我们就可以把该类声明成抽象类 接口: 我们在定义相互调用规则时,可以使用接口.面向接口进行编程的明显好处,就是能极大降低软件系统的相互耦合性,接口的定义者按照接口进行调用,而实现者去实现接口 2.list

C++强化学习规划表

第一阶段 C语言加强以及C++语言详解(29天) 课程名称 课程内容 学习目标 C语言强化 · C语言基础复习(数据类型.变量.内存布局.指针基础) · C语言基础强化提高(C语言中的字符串.一维数组.二维数组) · C语言基础强化提高(一级指针,二级指针,三级指针实战,N级指针概念,指针数组和数组指针) · C语言基础强化提高(结构体.文件的使用) · 动态库的封装和设计 · 函数指针回调函数 · C语言面试题强化与提高 在基础班C语言知识点之上,掌握C语言深入技巧,为日后 做更大的项目打下坚