hdoj 2000 ASCII码排序 用java写的解题报告
2014-03-12 08:57
274 查看
今天开始试着用java编写代码,首先得了解一下他的输入输出
下面就用杭电2000的题做例子
题目很简单,就不多说了,直接看代码
下面就用杭电2000的题做例子
题目很简单,就不多说了,直接看代码
import java.util.Scanner; public class Main { public static void main(String args[]){ Scanner cin = new Scanner(System.in); char[] s = new char[3]; while(cin.hasNext()){ String r = cin.next(); s[0] = r.charAt(0); s[1] = r.charAt(1); s[2] = r.charAt(2); char temp; for(int i=0;i<2;i++){ for(int j=1;j>=i;j--){ if(s[j+1] > s[j]){ temp = s[j+1]; s[j+1] = s[j]; s[j] = temp; } } } System.out.printf("%c %c %c\r\n",s[2],s[1],s[0]); } } }
java的输入输出有很多种,Scanner是其中一种,Scanner只有读取String的方法,但是却没有读取字符数组的方法,所以需要String r = cin.next();来接受输入,然后把他转化成字符数组(方法有两种,其中就是列子上写的那样,但是这样写特别不专业,还有一种是 s=r.toCharArray();),然后通过冒泡排序,最后输出。
这里的输出得念叨几句。
在C/C++中,我们可以使用\n或cout<<endl(C++语法)来换行,事实上,我们平时所说的换行都是先回车再换行,也就是先让光标跳至所在行首个位置,再跳至下一行,在本例中最后的System.out.printf中如果不加上\r(光标移至行首),OJ会报Presentation Error(PE),也就是格式错误。这里提供两种解决方法:①System.out.printf(“%s %s %s\r\n”, a[0],a[1],a[2]);②System.out.printf(“%s %s %s%n”, a[0],a[1],a[2]);这里%n的意思是指输出平台特定的换行字符,如果在Windows下实际会置换为\r\n,如果是在Linux下则会置换成\n。
相关文章推荐
- hdu 2000 ASCII码排序解题报告
- HDU 2000 ASCII码排序 解题报告
- hdu_2000_ASCII码排序_解题报告
- 剑指Offer解题报告(Java版)——排序数组中某个数的个数 38
- hdoj2012解题报告
- [leetcode]125. Valid Palindrome@Java解题报告
- hdoj-2564-词组缩写(解题报告)
- HDOJ 1087Super Jumping! Jumping! Jumping!解题报告
- HDOJ 3605 Escape 解题报告 二分图匹配 dinic 网络流
- 杭电HDOJ 1002 解题报告
- HDOJ 1239:Calling Extraterrestrial Intelligence Again 解题报告
- 【LeetCode】Binary Tree Paths 解题报告(java & python)
- HDOJ2000(ASC||码排序)【sort函数】
- 解题报告-HDOJ-1233(最小生成树——kruskal)
- POJ 1186 方程的解数 [解题报告] Java
- HDOJ-1398-Square Coins 解题报告
- Poj 1451 JAVA 个人解题报告
- [leetcode]107. Binary Tree Level Order Traversal II@Java解题报告
- 剑指offer解题报告(Java版)——二叉树的镜像 19
- HDOJ 1272 小希的迷宫解题报告