자바 집합 연습

6760 단어 Java
1. 한 중학교 에 몇 명의 학생 (학생 대상 은 하나의 List 에 놓 여 있 음) 이 있 고 모든 학생 은 이름 속성 (String), 학급 이름 속성 (String) 과 시험 성적 속성 (double) 이 있 습 니 다. 한 번 의 시험 이 끝 난 후에 모든 학생 들 은 하나의 시험 성적 을 받 았 습 니 다.list 집합 을 옮 겨 다 니 며 학생 대상 의 속성 을 인쇄 합 니 다.
package lianxi01;
public class Student {
private String name;
private String className;
private double score;
public String getName() {
    return name;
}
public void setName(String name) {
    this.name = name;
}
public String getClassName() {
    return className;
}
public void setClassName(String className) {
    this.className = className;
}
public double getScore() {
    return score;
}
public void setScore(double score) {
    this.score = score;
}
public Student(String name, String className, double score) {
    super();
    this.name = name;
    this.className = className;
    this.score = score;
}
public Student() {
    super();
    // TODO Auto-generated constructor stub
}
@Override
public String toString() {
    return "  :" + name + ",   :" + className + ",   :" + score ;
}

}
package lianxi01;
import java.util.ArrayList; import java.util.List;
public class Test {
public static void main(String[] args) {

    List list = new ArrayList();
    list.add(new Student("tom","2  3 ",90));
    list.add(new Student("jack","2  3 ",80));
    list.add(new Student("Lily","2  3 ",70));
    list.add(new Student("Lucy","2  3 ",60));

    for (Student student : list) {
        System.out.println(student);
    }

}

}
2. 프로그램 을 작성 하여 명령 행 매개 변수 에 있 는 문자열 목록 을 가 져 옵 니 다. 중 복 된 문자, 중복 되 지 않 는 문자, 중 복 된 문자 목록 을 제거 합 니 다.
package test;
import java.util.HashSet; import java.util.Set;
public class Lianxi02 {
public static void main(String[] args) {
    String str = "abcdeafblmbnopawc";
    System.out.println("    :"+str);


    Set set1 = new HashSet();//        
    Set set2 = new HashSet();//     
    Set set3 = new HashSet();//      

    //          
    char[] cs = str.toCharArray();
    for (char c : cs) {
        boolean b = set1.add(c);
        if(!b){
            set2.add(c);
        }
    }

    //           set3
    set3.addAll(set1);
    //          -       =       
    set3.removeAll(set2);

    System.out.println("====        ========");
    for (char c : set1) {
        System.out.print(c+" ");
    }

    System.out.println("
==== ========"); for (char c : set2) { System.out.print(c+" "); } System.out.println("
==== ========"); for (char c : set3) { System.out.print(c+" "); } }

}
3. Scanner 를 사용 하여 콘 솔 에서 문자열 을 읽 고 문자열 에 있 는 모든 문자 가 나타 나 는 횟수 를 통계 하 며 배 운 지식 으로 이상 의 요 구 를 완성 하도록 요구 합 니 다. 방향 은 set, List, Map 집합 특성 에 따라 이 루어 집 니 다.
package test;
import java.util.HashMap; import java.util.Map; import java.util.Set;
public class Lianxi03 {
public static void main(String[] args) {
    String str = "abcdeblmbac";
    System.out.println("    :"+str);

    Map map = new HashMap();
    char[] cs = str.toCharArray();

    for (char c : cs) {

        if(map.containsKey(c)){
            Integer value = map.get(c);
            value++;

            map.put(c, value);

        }else{
            map.put(c, 1);
        }   
    }
    //  map
    Set set = map.keySet();
    for (Character c : set) {
        System.out.println(c+"   "+map.get(c)+" ");
    }
}

}
4. Employee 클래스 를 정의 합 니 다. 속성: name: String, age: int, salary: double 은 몇몇 Employee 대상 을 List 에 두 고 정렬 하고 출력 을 옮 겨 다 닙 니 다. 정렬 규칙: salary 가 높 은 것 은 앞 에 있 고 salary 가 같은 시간 에 age 가 큰 것 은 앞 에 있 습 니 다. age 도 같은 시간 에 name 오름차 순 으로 배열 하여 마른 Employee 대상 을 set 에 두 고 옮 겨 다 니 며 중복 요소 가 없 도록 합 니 다.
package lianxi04;
public class Employee {
private String name;
private int age;
private double salary;
public String getName() {
    return name;
}
public void setName(String name) {
    this.name = name;
}
public int getAge() {
    return age;
}
public void setAge(int age) {
    this.age = age;
}
public double getSalary() {
    return salary;
}
public void setSalary(double salary) {
    this.salary = salary;
}
public Employee() {
    super();
    // TODO Auto-generated constructor stub
}
public Employee(String name, int age, double salary) {
    super();
    this.name = name;
    this.age = age;
    this.salary = salary;
}
@Override
public String toString() {
    return "  :" + name + ",   :" + age + ",   :" + salary ;
}

}
package lianxi04;
import java.util.ArrayList; import java.util.List;
public class Test {
public static void main(String[] args) {

    Employee e1 = new Employee("Alis",20,3000);
    Employee e2 = new Employee("Tom",22,3000);
    Employee e3 = new Employee("Jack",22,3000);
    Employee e4 = new Employee("Lily",21,3500);
    Employee e5 = new Employee("Mike",20,2900);
    Employee e6 = new Employee("Bobo",23,4000);

    List list = new ArrayList();
    list.add(e1);
    list.add(e2);
    list.add(e3);
    list.add(e4);
    list.add(e5);
    list.add(e6);


    //  
    for (Employee e : list) {
        System.out.println(e);
    }

    System.out.println("=============   ================");

    for (int i = 1; i < list.size(); i++) { 

        for (int j = 0; j < list.size() - i; j++) { 
            Employee emp1 = list.get(j);
            Employee emp2 = list.get(j+1);

            //    
            if(emp1.getSalary() < emp2.getSalary()){
                list.set(j, emp2);
                list.set(j+1, emp1);
            }else if(emp1.getSalary() == emp2.getSalary()){
                //    
                if(emp1.getAge() < emp2.getAge()){
                    list.set(j, emp2);
                    list.set(j+1, emp1);
                }else if(emp1.getAge() == emp2.getAge()){
                    if(emp1.getName().compareTo(emp2.getName()) > 0 ){
                        list.set(j, emp2);
                        list.set(j+1, emp1);
                    }
                }
            }
        }

    }

    //  
    for (Employee e : list) {
        System.out.println(e);
    }

}

}

좋은 웹페이지 즐겨찾기