자바 집합 연습
6760 단어 Java
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);
}
}
}
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
JPA + QueryDSL 계층형 댓글, 대댓글 구현(2)이번엔 전편에 이어서 계층형 댓글, 대댓글을 다시 리팩토링해볼 예정이다. 이전 게시글에서는 계층형 댓글, 대댓글을 구현은 되었지만 N+1 문제가 있었다. 이번에는 그 N+1 문제를 해결해 볼 것이다. 위의 로직은 이...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.