- 浏览: 608159 次
- 性别:
- 来自: 北京
文章分类
最新评论
今天来点新鲜的,来一道我没答案的题
现将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的后面,试着做做就知道我说什么了,呵呵
不知是否可以使用吧text1.txt中的字符编程ascii码,吧英文提炼出来然后按照ascii码的大小排序..然后吧数字提炼出来 放到集合里面 使用Collection.sort(); 再吧前面的字符和后面的数字 结合起来..放到text2里面去..这样不知是否可以.?
我也是这种
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);
就可以正常排序了
确实,又学到了~~多谢~~~
干嘛还要写一个排序的算法..用sort排序不简单些么
如果你动手试下就知道了,如果用api中提供的排序方法,10是在1之后的
输出text2文件 正常显示,但是在51行若写成return chart+","+num;即逗号后没有空格的话也会出现乱码, aben6448可以参考一下,至于为什么还请高人解释。
现将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的后面,试着做做就知道我说什么了,呵呵
评论
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)){
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);
就可以正常排序了
确实,又学到了~~多谢~~~
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);
就可以正常排序了
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>
<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
上代码
觉得繁琐了点,不知哪位牛人能提出好办法
另外,在最后写入text2.txt文件中时,写入的数据乱码,但之前输出的结果是正常的,不知道为什么,期待牛人解答~~
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里面去..这样不知是否可以.?
然后按照ascii码的大小排序..
然后吧数字提炼出来 放到集合里面 使用Collection.sort();
再吧前面的字符和后面的数字 结合起来..放到text2里面去..这样不知是否可以.?
1 楼
zxd7900663
2009-02-26
up up !
发表评论
-
用Java解PythonChallenge(第二天)
2009-08-02 11:49 14313. import java.io.BufferedRea ... -
用Java解PythonChallenge(第一天)
2009-08-01 21:20 2539www.pythonchallenge.com是一个学习pyt ... -
Java每日一题24(最后一题)
2009-03-06 11:10 1659昨天又写了个双色球程序,作为Java每日一题系列的终止符: J ... -
Java每日一题23
2009-03-05 11:23 3247来个数学性强的,c语言书中找到的 有13个人围成一圈,从第一 ... -
Java每日一题22
2009-03-04 09:45 2708开始新一轮的学习吧,今天来个比较有意思的 有一个字符串Stri ... -
Java每日一题21
2009-03-03 10:26 1743也是出自C的,不过都是跟数学相关的,最看重算法 明天开始回归正 ... -
Java每日一题20
2009-03-02 10:56 2400纪念每日一题出到第20期 最近在看Linux下的c开发,所以把 ... -
Java每日一题19
2009-02-27 10:03 2334今天是周末,再来一道没有答案的题,没事的朋友coding下,放 ... -
Java每日一题17
2009-02-25 11:27 1987编写一个JAVA程序,从输入的一个字符串中提取出数字并组成一个 ... -
Java每日一题16
2009-02-24 11:25 1530最近项目开始了,比较繁忙,所以发题只能等到快到午饭的休息时间, ... -
Java每日一题15
2009-02-23 10:40 2110时间系列的题暂时告一段落,在此期间,这些问题有了很多新的解决方 ... -
Java每日一题14
2009-02-20 11:29 2116热烈庆祝我的blog被选入javaeye论坛的首页滚动栏!!! ... -
Java每日一题13
2009-02-19 11:00 1597编程实现将用户输入的24小时制时间转换为12小时制时间 找到 ... -
Java每日一题12
2009-02-18 12:10 1435如何得到一年的所有星期二的日期? package test2 ... -
Java每日一题11
2009-02-17 10:58 1904根据一个TimeZone的时间,比如一个“Africa/Acc ... -
Java每日一题10
2009-02-16 10:19 2322看到有越来越多的人来参与到我的Java每日一题系列,非常开心: ... -
Java每日一题09
2009-02-13 10:50 1765准备从下星期开始推出”时间处理系列“,”字符串系列“,”打印格 ... -
Java每日一题08
2009-02-12 10:31 2461编写一个辅助小学生学习乘法的程序。使用一个Random对象产生 ... -
Java每日一题07
2009-02-11 11:00 2840通过键盘输入一个字符串,判断字符串中出现最多的字符并输出该字符 ... -
Java每日一题06
2009-02-10 11:18 2074这道题毕业找工作的时候常考 输入一个字符串,按相反顺序输出该字 ...
相关推荐
【标题】"JAVA每日一题20"是一个关于Java编程的挑战题目,旨在提升开发者对Java语言的理解和应用能力。通常这类题目会涉及到Java的核心概念、语法特性或者常见问题的解决策略。 【描述】虽然描述部分为空,但根据...
Java每日一题20160906,每日一道Java编程题,提高自己
【标题】"JAVA每日一题11"是一个关于Java编程的日常练习问题,可能是从某个技术社区或博客中提取的。通常,这类题目旨在帮助开发者巩固基础,提升技能,或者探讨一些特定的Java编程概念。从提供的信息来看,我们无法...
NULL 博文链接:https://jythoner.iteye.com/blog/344407
标题“JAVA每日一题08”暗示我们今天将探讨与Java编程语言相关的技术问题,可能是某个挑战或难题的解决方案。由于没有提供具体的题目内容,我们可以从更广泛的Java知识角度出发,结合“源码”和“工具”这两个标签来...
根据给定的信息,我们可以归纳出以下几个关键的Java知识点: ### 1. 在屏幕上输出文本 ...这些练习题覆盖了Java语言的基础语法、控制结构以及面向对象编程的基本概念,非常适合初学者进行日常练习。
【标题】:“每日一题20190628_java面试题_”是指一个针对Java程序员的面试问题集合,可能包含各种Java编程语言、框架、设计模式以及系统架构等相关问题,旨在帮助求职者准备面试。 【描述】:“java面试题,参考...
Java面试题-每日一题:String、StringBuffer、StringBuilder的区别
在给定的编程题中,我们需要判断一个字符串是否为回文串。回文串是指正读反读都一样的字符串,例如"madam"或"level"。Java中,我们可以利用String类提供的方法来实现回文串的判断。解题思路是使用两个指针,一个从...
【Java编程题解析】 在Java编程中,我们经常会遇到各种挑战性的题目,旨在提升我们的编程能力和算法思维。这里有两个不同的编程题目,让我们一一解析。 ### 题目1:DNA序列链接 - 找到GC比例最大的子串 #### 题目...
题目中给出了一个类A及其成员变量和方法的定义,询问了哪些调用是错误的,这涉及到对Java成员访问规则的理解。 以上知识点涵盖了Java多线程、序列化、面向对象设计、变量存储、类型转换、运算符优先级、方法存储、...
Java是一种面向对象的编程语言,其核心特性之一就是封装,这是OOP(面向对象编程)的三大特性之一,另外两个是继承和多态。封装的主要目的是保护数据的安全性,通过限制对类内部成员的直接访问,防止外部代码随意...
"Java方向每日一题day17_11月24日编程题答案1" 在本题中,我们需要解决一个火车进站的问题,给定n辆火车的编号,要求计算出所有可能的出站顺序。该问题可以使用栈来解决,因为栈的出栈顺序满足后进先出(Last In ...
在题目中,有几道关于Java语言特性和语法的单选题: 1. 类实例化语句的正确选项是D。 2. 描述错误的Java语言特点选项是C,因为Java是面向对象的语言,而非面向过程。 3. 编译并运行给定的代码`public class Pvf{ ...
本项目为LeetCode每日一题的Java编程语言解答源码,总计包含223个文件,包括202个Java源文件、7个Markdown文件、6个JSON文件、4个JAR包文件以及少量其他类型文件。这些源码旨在帮助开发者通过实践解决LeetCode上的...
整理互联网常见面试题,为春招、校招和社招做准备。如若不能下载,关注公众号“每日技术分享”,可免费下载资源。
干货资源推荐: JVM干货调试视频教程分享 50份优秀Java求职者简历 SpringCloud前后端分离实战项目...本资源整理自互联网,仅供学习交流使用,请勿商用,坚持每日分享一套Java学习资源干货,一起提高,一起进步!!!
LeetCode的每日一题是平台上的一个特色功能,每天会发布一个新的编程题目,涵盖各种难度级别,从基础到进阶,涉及语言包括Java、Python、C++等。这些题目涵盖了数据结构(如数组、链表、栈、队列、树、图等)和算法...
【Java面试题大全-图形图像篇】 在Java面试中,图形图像处理是一个常见的技术领域,涉及到Java AWT(Abstract Window Toolkit)和Swing组件库,以及更高级的JavaFX。这些框架提供了创建用户界面和图形内容的能力。...
本项目"leetcode-java:每日一题leetcode-java版"是针对LeetCode平台的Java解决方案集,旨在帮助Java开发者通过每日解决一个LeetCode题目来提高他们的算法理解和编程能力。 在Java编程语言中,解决问题的关键在于...