- 浏览: 602041 次
- 性别:
- 来自: 北京
文章分类
最新评论
今天来点新鲜的,来一道我没答案的题
现将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 14033. import java.io.BufferedRea ... -
用Java解PythonChallenge(第一天)
2009-08-01 21:20 2494www.pythonchallenge.com是一个学习pyt ... -
Java每日一题24(最后一题)
2009-03-06 11:10 1628昨天又写了个双色球程序,作为Java每日一题系列的终止符: J ... -
Java每日一题23
2009-03-05 11:23 3190来个数学性强的,c语言书中找到的 有13个人围成一圈,从第一 ... -
Java每日一题22
2009-03-04 09:45 2660开始新一轮的学习吧,今天来个比较有意思的 有一个字符串Stri ... -
Java每日一题21
2009-03-03 10:26 1694也是出自C的,不过都是跟数学相关的,最看重算法 明天开始回归正 ... -
Java每日一题20
2009-03-02 10:56 2368纪念每日一题出到第20期 最近在看Linux下的c开发,所以把 ... -
Java每日一题19
2009-02-27 10:03 2301今天是周末,再来一道没有答案的题,没事的朋友coding下,放 ... -
Java每日一题17
2009-02-25 11:27 1952编写一个JAVA程序,从输入的一个字符串中提取出数字并组成一个 ... -
Java每日一题16
2009-02-24 11:25 1508最近项目开始了,比较繁忙,所以发题只能等到快到午饭的休息时间, ... -
Java每日一题15
2009-02-23 10:40 2086时间系列的题暂时告一段落,在此期间,这些问题有了很多新的解决方 ... -
Java每日一题14
2009-02-20 11:29 2080热烈庆祝我的blog被选入javaeye论坛的首页滚动栏!!! ... -
Java每日一题13
2009-02-19 11:00 1557编程实现将用户输入的24小时制时间转换为12小时制时间 找到 ... -
Java每日一题12
2009-02-18 12:10 1410如何得到一年的所有星期二的日期? package test2 ... -
Java每日一题11
2009-02-17 10:58 1873根据一个TimeZone的时间,比如一个“Africa/Acc ... -
Java每日一题10
2009-02-16 10:19 2292看到有越来越多的人来参与到我的Java每日一题系列,非常开心: ... -
Java每日一题09
2009-02-13 10:50 1736准备从下星期开始推出”时间处理系列“,”字符串系列“,”打印格 ... -
Java每日一题08
2009-02-12 10:31 2424编写一个辅助小学生学习乘法的程序。使用一个Random对象产生 ... -
Java每日一题07
2009-02-11 11:00 2809通过键盘输入一个字符串,判断字符串中出现最多的字符并输出该字符 ... -
Java每日一题06
2009-02-10 11:18 2040这道题毕业找工作的时候常考 输入一个字符串,按相反顺序输出该字 ...
相关推荐
Java每日一题20160906,每日一道Java编程题,提高自己
NULL 博文链接:https://duyiwuer.iteye.com/blog/362849
NULL 博文链接:https://duyiwuer.iteye.com/blog/353541
NULL 博文链接:https://jythoner.iteye.com/blog/344407
java每日一练练习题
Java方向每日一题day18_11月25日编程题答案1
NULL 博文链接:https://duyiwuer.iteye.com/blog/351913
Java方向每日一题day17_11月24日编程题答案1
java面试题,参考面试使用,与什么不懂的不用联系我,我随便传的东西,不传不让下载,真烦
9. 以下关于java封装的描述中,正确的是: 1. 标题:DNA序列 | 时间限制:1秒 | 内存限制:32768K 2. 标题:百万富翁问题 | 时间限制:
比特科技制作[编程题]44581-寻找第K大链接:https://www.nowcoder.com/questionTerminal/e016ad9b7f0b4
1. 执行如下程序,输出结果是( ) 3. 下列选项中属于面向对象设计方法主要特征的是( ) 6. 在基本 JAVA 类型中,如果不明确指定,整数型的默认是 _
整理互联网常见面试题,为春招、校招和社招做准备。如若不能下载,关注公众号“每日技术分享”,可免费下载资源。
干货资源推荐: JVM干货调试视频教程分享 50份优秀Java求职者简历 SpringCloud前后端分离实战项目...本资源整理自互联网,仅供学习交流使用,请勿商用,坚持每日分享一套Java学习资源干货,一起提高,一起进步!!!
leetcode-java:每日一题leetcode-java版
1. 以下哪项是类实例化的语句 6. 变量a是一个64位有符号的整数,初始值用16进制表示为:0Xf000000000000000 7. HashSet子类依靠
一些考试的java习题,一些试卷,考生可能用处大点
leetcode 答案 leetcode-java 每日更新一题,Java编写的LeetCode算法题目答案。
Leetcode每日LeetCode每日一题Java实现
推出了每日一题活动。借此打卡! ID Difficulty Solution Series Finish Time Java C C++ Address 1 ☆ 2019-02-29 ✓ 225 ☆ 每日一题 2020-03-01 ✓ 206 ☆ 每日一题 2020-03-02 ✓ 面试题 ☆ 每日一题 2020-03-03...