码迷,mamicode.com
首页 > 编程语言 > 详细

将控制台输入的资料存到文档中,并按照存入资料的年龄进行排序

时间:2017-10-12 19:12:18      阅读:200      评论:0      收藏:0      [点我收藏+]

标签:buffere   rate   关联   lis   数组排序   排序   cto   span   split   

package LX10_11;

 

import java.io.BufferedReader;

import java.io.BufferedWriter;

import java.io.File;

import java.io.FileNotFoundException;

import java.io.FileReader;

import java.io.FileWriter;

import java.io.IOException;

import java.io.InputStreamReader;

import java.util.ArrayList;

import java.util.Collections;

import java.util.List;

 

public class WenJian {

 

public static  void main(String[] args) throws IOException  {

 

List<KeHu> list = new ArrayList<KeHu>();//创建一个集合,存放文件中截取到的客户资料

 

//关联文件

File file1=new File("E:\\客户资料.txt");

BufferedWriter bw = new BufferedWriter(new FileWriter(file1));

//判断file1是否存在,不存在就创建file1

try {

if(file1.createNewFile()) {

System.out.println("[成功创建]");

}else {

System.out.println( "[文件存在-不覆盖创建]");

}

} catch (IOException e1) {

// TODO Auto-generated catch block

e1.printStackTrace();

}

 

//从控制台给文件中写内容

BufferedReader br1 = new BufferedReader(new InputStreamReader(System.in));

String line=br1.readLine();

while(!line.equals("cl")) {

bw.write(line);

line=br1.readLine();

}

//关闭

br1.close();

bw.flush();

bw.close();

 

//用集合实现排序

//jihe(list, file1);

 

ShuZu(file1);

 

 

}

 

private static void ShuZu(File file1) throws FileNotFoundException, IOException {

KeHu str[] = new KeHu[4];//创建数组存放客户对象

 

BufferedReader br = new BufferedReader(new FileReader(file1));

String s1 = br.readLine();

String[] t1 = s1.split("");

String[] t2 = new String[2];

 

int a=0;

for(String i:t1) {

//System.out.println("i的值---"+i);

t2=i.split("");

String name = t2[0];

int age = Integer.parseInt(t2[1]);

KeHu kh = new KeHu(name,age);

str[a]=kh;

a++;

}

 

System.out.println("用数组排序前----------");

for(KeHu h:str) {

System.out.println(h);

}

 

//对存入对象的年龄按从小到大的顺序排列,冒泡法

for(int i=0;i<str.length-1;i++) {

for(int j=0;j<str.length-i-1;j++) {

KeHu t;

if(str[j].getAge()>str[j+1].getAge()) {

t = str[j];

str[j] = str[j+1];

str[j+1] = t;

}

}

}

 

System.out.println("用数组排序后------");

for(KeHu h:str) {

System.out.println(h);

}

}

 

private static void jihe(List<KeHu> list, File file1) throws FileNotFoundException, IOException {

BufferedReader br = new BufferedReader(new FileReader(file1));

String s1 = br.readLine();

String[] t1 = s1.split("");

String[] t2 = new String[2];

for(String i:t1) {

//System.out.println("i的值---"+i);

t2=i.split("");

String name = t2[0];

int age = Integer.parseInt(t2[1]);

KeHu kh = new KeHu(name,age);

list.add(kh);

//System.out.println(kh);

}

System.out.println("用集合排序前:\n"+list);

 

Collections.sort(list);//对集合中元素按年龄进行排序

System.out.println("用集合排序后:\n"+list);

}

 

}

 

package LX10_11;

 

public class KeHu implements Comparable<KeHu>{

 

private String name;

private int age;

 

 

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 KeHu() {

super();

// TODO Auto-generated constructor stub

}

public KeHu(String name, int age) {

super();

this.name = name;

this.age = age;

}

@Override

public String toString() {

return "名字=" + name + ", 年龄" + age ;

}

 

@Override

public int compareTo(KeHu o) {

 

if(this.age>o.getAge()) {

return -1;

}else if(this.age>o.getAge()) {

return 0;

}else {

return 1;

}}}

将控制台输入的资料存到文档中,并按照存入资料的年龄进行排序

标签:buffere   rate   关联   lis   数组排序   排序   cto   span   split   

原文地址:http://www.cnblogs.com/y-zz/p/7657237.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!