`
jythoner
  • 浏览: 609103 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

Java每日一题18

阅读更多
今天来点新鲜的,来一道我没答案的题

现将TEXT1.TXT中的文本内容 复制到TEXT2.TXT中 并对其内容进行排序
TEXT1.TXT中的文本内容为:b,5,q,10,f,6,9,d,3,c,1,e,4,2,7,8,a
最后输出结果为:a,b,c,d,e,f
1,2,3,4,5,6,7,8,9,10


难点在10要排在9的后面,试着做做就知道我说什么了,呵呵

9
4
分享到:
评论
13 楼 ccjsjymg 2009-02-28  
package util;

import java.util.regex.Matcher;
import java.util.regex.Pattern;

/**
 * 字符串中按照字母和数字分别排序
 * @author zl
 */
public class SortString {
	private static String STR = "b,5,q,10,f,6,9,d,3,c,1,e,4,2,7,8,a";
	public static void sortGroupBy(String str){
		String[] ss = str.split(",");
		String _char = "";
		String _digit = "";
		for(int i = 0;i < ss.length;i++){
			if(regex(ss[i])){
				if("".equals(_digit)){
					_digit += ss[i];
				}else{
					_digit += ","+ss[i];
				}
			}else{
				if("".equals(_char)){
					_char += ss[i];
				}else{
					_char += ","+ss[i];
				}
			}
		}
		getSortString(_char);
		getSortString(_digit);
	}
	public static void getSortString(String ss){
		if(!StringHelper(ss)) return;
		String _ts = "";
		if(ss.indexOf(",") != -1){
			String[] ts = ss.split(",");
			for(int i = 0;i < ts.length;i++){
				for(int j = 0;j < i;j++){
					if(regex(ts[i])){
						if(Integer.parseInt(ts[j]) > Integer.parseInt(ts[i])){
							String temp = ts[j];
							ts[j] = ts[i];
							ts[i] = temp;
						}
					}else{
						if(ts[j].charAt(0) > ts[i].charAt(0)){
							String temp = ts[j];
							ts[j] = ts[i];
							ts[i] = temp;
						}
					}
					
				}
			}
			for(int k = 0;k < ts.length;k++){
				if("".equals(_ts)){
					_ts += ts[k];
				}else{
					_ts += ","+ts[k];
				}
			}
			System.out.println(_ts);
		}
	}
	public static boolean StringHelper(String s){
		if(s != null && !"".equals(s)){
			return true;
		}else{
			return false;
		}
	}
	public static boolean regex(String s){
		Pattern p = Pattern.compile("[0-9]*");
		Matcher m = p.matcher(s);
		if(m.matches()){
			return true;
		}
		return false;
	}
	public static void main(String[] args) {
		sortGroupBy(STR);
	}
}

12 楼 forgetOneself 2009-02-27  
ramus 写道

不知是否可以使用吧text1.txt中的字符编程ascii码,吧英文提炼出来然后按照ascii码的大小排序..然后吧数字提炼出来 放到集合里面 使用Collection.sort(); 再吧前面的字符和后面的数字 结合起来..放到text2里面去..这样不知是否可以.?

我也是这种
11 楼 aben6448 2009-02-27  
dumylove 写道

if(strs[i].matches(re)){&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; nums.add(strs[i]);&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; }&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; else{&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; chars.add(strs[i]);&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; }&nbsp;&nbsp;

这段代码修改一下,会更简单
if(strs[i].matches(re)){&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; nums.add(Integer.parseInt(strs[i]));&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; }&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; else{&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; chars.add(strs[i]);&nbsp;&nbsp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp; }&nbsp;&nbsp;

这样个修改后,在使用Collections.sort(nums);
就可以正常排序了


确实,又学到了~~多谢~~~
10 楼 dumylove 2009-02-27  
if(strs[i].matches(re)){  
                nums.add(strs[i]);  
            }  
            else{  
                chars.add(strs[i]);  
            }  

这段代码修改一下,会更简单
if(strs[i].matches(re)){  
                nums.add(Integer.parseInt(strs[i]));  
            }  
            else{  
                chars.add(strs[i]);  
            }  

这样个修改后,在使用Collections.sort(nums);
就可以正常排序了
9 楼 failure5152 2009-02-27  
我写得也很烦,希望看到简单的方法。
8 楼 failure5152 2009-02-27  
import java.io.BufferedReader;
import java.io.File;
import java.io.FileOutputStream;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.io.PrintWriter;
import java.util.ArrayList;
import java.util.Arrays;
/**
 * 1.txt放在当前类的包中
 *
 */
public class SortText {
	public static void main(String[] args) throws Exception {

		InputStream in = SortText.class.getResourceAsStream("1.txt");
		BufferedReader br = new BufferedReader(new InputStreamReader(in));
		String content = br.readLine();
		String[] arrary = content.split(",");
		ArrayList<Integer> numList = new ArrayList<Integer>();
		ArrayList<String> strList = new ArrayList<String>();
		for (String str : arrary) {
			try {
				int numer = Integer.parseInt(str);
				numList.add(numer);
			} catch (NumberFormatException nfe) {
				strList.add(str);
			}
		}
		Integer[] numArray = numList.toArray(new Integer[0]);
		String[] strArray = strList.toArray(new String[0]);
		Arrays.sort(numArray);
		Arrays.sort(strArray);
		StringBuilder sb = new StringBuilder();
		for (int i = 0; i < strArray.length; i++) {
			if (i > 0) {
				sb.append(",");
			}
			sb.append(strArray[i]);
		}

		for (int i = 0; i < numArray.length; i++) {
			if (sb.length() == 0)
				sb.append(numArray[i]);
			else
				sb.append(",").append(numArray[i]);
		}
		String result = sb.toString();
		String path = SortText.class.getResource("").getPath();//等到当前路径,2.txt与1.txt放在同一个目录中
		File newFile = new File(path + "2.txt");
		PrintWriter pw = new PrintWriter(new FileOutputStream(newFile));
		pw.print(result);
		pw.flush();
		pw.close();
	}

}
7 楼 yf42 2009-02-26  
自己改下Comparator就行了,万一以后想改排序规则还得看那么一大堆代码
<code>
class Comp implements Comparator{

public int compare(Object obj1, Object obj2) {
String str1 = (String)obj1;
String str2 = (String)obj2;
if(str1.matches("\\D")&&str2.matches("\\D")){
return str1.compareTo(str2);
}else if(str1.matches("\\D")&&str2.matches("\\d")){
return -1;
}else if(str1.matches("\\d")&&str2.matches("\\D")){
return 1;
}else{
return Integer.parseInt(str1)-Integer.parseInt(str2);
}
}
}
</code>
调用的时候
<code>
Arrays.sort(array, new Comp());
</code>
6 楼 jythoner 2009-02-26  
ramus 写道

干嘛还要写一个排序的算法..用sort排序不简单些么

如果你动手试下就知道了,如果用api中提供的排序方法,10是在1之后的
5 楼 ramus 2009-02-26  
干嘛还要写一个排序的算法..用sort排序不简单些么
4 楼 orchid123 2009-02-26  
import java.io.BufferedWriter;
import java.io.File;
import java.io.FileReader;
import java.io.FileWriter;
import java.io.IOException;
import java.util.*;
public class J0226 {
		public String sortTxt(String txt){
			String chart="";
			String num="";
			String str="";
			int[] nn=new int[txt.length()];
			int k,f;
			final   String   number   =   "0123456789";   
			String[] txtArray=txt.split("\\,");
			k=0;
			for(int i=0;i<txtArray.length;i++){
				str=txtArray[i];
				f=0;
                for(int j = 0;j < str.length();j++){   
                        if (number.indexOf(str.charAt(j)) ==-1){   
                              chart = chart+','+str;
                              f=1;
                              break;
                         }   
                }   
                if(f==0){
                	nn[k]=Integer.parseInt(str);
                	k++;
                }                
			}
			chart=chart.substring(1);
			String[] charArr=chart.split(",");
			Arrays.sort(charArr);
			Arrays.sort(nn);
			chart="";
			for(int i=0;i<nn.length ;i++){
				if(nn[i]!=0){
					num=num+","+Integer.toString(nn[i]);
				}				
			}
			num =num.substring(1);
			for(int i=0;i<charArr.length;i++){
				chart=chart+charArr[i]+",";
			}
			chart=chart.substring(0,chart.length()-1);
			System.out.println(chart);
			System.out.println(num);
			return chart+", "+num;			
		}
		public static void main(String[] args) throws IOException{
			J0226 jj=new J0226();
			File f1=new File("d:\\text1.txt");
			 FileReader fr=new FileReader(f1);
			 BufferedReader br=new BufferedReader(fr);
			 String read="";
			 String r="";
			    while((r=br.readLine())!=null){
			    	read=r+','+read;
			    }    
			 
            read= read.substring(0,read.length()-1);  
//			String result=jj.sortTxt("b,5,q,10,f,6,9,d,3,c,1,e,4,2,7,8,a");	
			    String result=jj.sortTxt(read);
			File f2=new File("d:\\text2.txt");
			BufferedWriter writer = new BufferedWriter(new FileWriter(f2));
			writer.write(result);
			writer.close();
		}
}

输出text2文件 正常显示,但是在51行若写成return chart+","+num;即逗号后没有空格的话也会出现乱码, aben6448可以参考一下,至于为什么还请高人解释。
3 楼 aben6448 2009-02-26  
上代码
public static void main(String[] args) throws IOException {
		File f1=new File("d:\\text1.txt");
		String Str = "";
		BufferedReader reader = new BufferedReader(new FileReader(f1));
		String line = "";
		while ((line = reader.readLine()) != null) {
			Str = Str + line;
		}
		String[] strs=Str.split(",");
		ArrayList nums=new ArrayList();
		ArrayList chars=new ArrayList();
		String re="^\\d+";
		for (int i = 0; i < strs.length; i++) {
			if(strs[i].matches(re)){
				nums.add(strs[i]);
			}
			else{
				chars.add(strs[i]);
			}
		}
		int[] numarray=new int[nums.size()];
		for (int i = 0; i < nums.size(); i++) {
			numarray[i]=Integer.valueOf(nums.get(i).toString());
		}
		Object[] chararray=chars.toArray();
		Arrays.sort(numarray);
		Arrays.sort(chararray);
		String result="";
		for (int i = 0; i < chararray.length; i++) {
			result=result+chararray[i].toString()+",";
		}
		for (int i = 0; i < numarray.length; i++) {
			result=result+String.valueOf(numarray[i])+",";
		}
		result=result.substring(0,result.length()-1);
		System.out.println(result);
		File f2=new File("d:\\text2.txt");
		BufferedWriter writer = new BufferedWriter(new FileWriter(f2));
		writer.write(result);
		writer.close();
	}

觉得繁琐了点,不知哪位牛人能提出好办法
另外,在最后写入text2.txt文件中时,写入的数据乱码,但之前输出的结果是正常的,不知道为什么,期待牛人解答~~
2 楼 ramus 2009-02-26  
不知是否可以使用吧text1.txt中的字符编程ascii码,吧英文提炼出来

然后按照ascii码的大小排序..

然后吧数字提炼出来 放到集合里面 使用Collection.sort();

再吧前面的字符和后面的数字 结合起来..放到text2里面去..这样不知是否可以.?
1 楼 zxd7900663 2009-02-26  
up up !

相关推荐

    JAVA每日一题20

    【标题】"JAVA每日一题20"是一个关于Java编程的挑战题目,旨在提升开发者对Java语言的理解和应用能力。通常这类题目会涉及到Java的核心概念、语法特性或者常见问题的解决策略。 【描述】虽然描述部分为空,但根据...

    Java每日一题20160906

    Java每日一题20160906,每日一道Java编程题,提高自己

    JAVA每日一题11

    【标题】"JAVA每日一题11"是一个关于Java编程的日常练习问题,可能是从某个技术社区或博客中提取的。通常,这类题目旨在帮助开发者巩固基础,提升技能,或者探讨一些特定的Java编程概念。从提供的信息来看,我们无法...

    Java每日一题24(最后一题)

    NULL 博文链接:https://jythoner.iteye.com/blog/344407

    JAVA每日一题08

    标题“JAVA每日一题08”暗示我们今天将探讨与Java编程语言相关的技术问题,可能是某个挑战或难题的解决方案。由于没有提供具体的题目内容,我们可以从更广泛的Java知识角度出发,结合“源码”和“工具”这两个标签来...

    java每日一练练习

    根据给定的信息,我们可以归纳出以下几个关键的Java知识点: ### 1. 在屏幕上输出文本 ...这些练习题覆盖了Java语言的基础语法、控制结构以及面向对象编程的基本概念,非常适合初学者进行日常练习。

    每日一题20190628_java面试题_

    【标题】:“每日一题20190628_java面试题_”是指一个针对Java程序员的面试问题集合,可能包含各种Java编程语言、框架、设计模式以及系统架构等相关问题,旨在帮助求职者准备面试。 【描述】:“java面试题,参考...

    Java面试题-每日一题:String、StringBuffer、StringBuilder的区别

    Java面试题-每日一题:String、StringBuffer、StringBuilder的区别

    每日一题Java方向编程题答案day011

    在给定的编程题中,我们需要判断一个字符串是否为回文串。回文串是指正读反读都一样的字符串,例如"madam"或"level"。Java中,我们可以利用String类提供的方法来实现回文串的判断。解题思路是使用两个指针,一个从...

    Java方向每日一题day18_11月25日编程题答案1

    【Java编程题解析】 在Java编程中,我们经常会遇到各种挑战性的题目,旨在提升我们的编程能力和算法思维。这里有两个不同的编程题目,让我们一一解析。 ### 题目1:DNA序列链接 - 找到GC比例最大的子串 #### 题目...

    每日一题Java方向选择题答案day011

    题目中给出了一个类A及其成员变量和方法的定义,询问了哪些调用是错误的,这涉及到对Java成员访问规则的理解。 以上知识点涵盖了Java多线程、序列化、面向对象设计、变量存储、类型转换、运算符优先级、方法存储、...

    Java方向每日一题day18_11月25日选择题答案1

    Java是一种面向对象的编程语言,其核心特性之一就是封装,这是OOP(面向对象编程)的三大特性之一,另外两个是继承和多态。封装的主要目的是保护数据的安全性,通过限制对类内部成员的直接访问,防止外部代码随意...

    Java方向每日一题day17_11月24日编程题答案1

    "Java方向每日一题day17_11月24日编程题答案1" 在本题中,我们需要解决一个火车进站的问题,给定n辆火车的编号,要求计算出所有可能的出站顺序。该问题可以使用栈来解决,因为栈的出栈顺序满足后进先出(Last In ...

    java方向每日一题day17_11月24日选择题答案1

    在题目中,有几道关于Java语言特性和语法的单选题: 1. 类实例化语句的正确选项是D。 2. 描述错误的Java语言特点选项是C,因为Java是面向对象的语言,而非面向过程。 3. 编译并运行给定的代码`public class Pvf{ ...

    基于LeetCode每日一题的Java编程语言设计源码分享

    本项目为LeetCode每日一题的Java编程语言解答源码,总计包含223个文件,包括202个Java源文件、7个Markdown文件、6个JSON文件、4个JAR包文件以及少量其他类型文件。这些源码旨在帮助开发者通过实践解决LeetCode上的...

    java互联网面试题整理

    整理互联网常见面试题,为春招、校招和社招做准备。如若不能下载,关注公众号“每日技术分享”,可免费下载资源。

    2020年java常见面试题汇总%28附答案%29.pdf

    干货资源推荐: JVM干货调试视频教程分享 50份优秀Java求职者简历 SpringCloud前后端分离实战项目...本资源整理自互联网,仅供学习交流使用,请勿商用,坚持每日分享一套Java学习资源干货,一起提高,一起进步!!!

    leetcode每日一题总结.zip

    LeetCode的每日一题是平台上的一个特色功能,每天会发布一个新的编程题目,涵盖各种难度级别,从基础到进阶,涉及语言包括Java、Python、C++等。这些题目涵盖了数据结构(如数组、链表、栈、队列、树、图等)和算法...

    java面试题大全-葵花宝典 - 图形图像 - 道客巴巴

    【Java面试题大全-图形图像篇】 在Java面试中,图形图像处理是一个常见的技术领域,涉及到Java AWT(Abstract Window Toolkit)和Swing组件库,以及更高级的JavaFX。这些框架提供了创建用户界面和图形内容的能力。...

    leetcode-java:每日一题leetcode-java版

    本项目"leetcode-java:每日一题leetcode-java版"是针对LeetCode平台的Java解决方案集,旨在帮助Java开发者通过每日解决一个LeetCode题目来提高他们的算法理解和编程能力。 在Java编程语言中,解决问题的关键在于...

Global site tag (gtag.js) - Google Analytics