您的位置:首页 > 编程语言 > Java开发

“找女神要QQ号码”——跟风篇java新手版(求指点)

2015-06-21 14:25 323 查看
  吃完粽子后闲来无事,于是准备在园子里面看看。突然看到了一个找女神要QQ号码的文章,顿时精力充沛了~~^_^。

该文章楼主说明此算法来自于《啊哈!算法》,图文并茂,非常不错。《啊哈!算法》.pdf下载地址:http://vdisk.weibo.com/s/zzBPqzw3MPnbM

本来只是看看而已,结果发现评论很火爆,都在发自己的实现代码。

比如:美女程序员是如何将QQ转换成题目中那串数字的--读博文《找女神要QQ号码》 http://www.cnblogs.com/net-xiejun/p/4589594.html

我等初学者也必定想去凑凑热闹。



题目就是这样的:

给了一串数字(不是QQ号码),根据下面规则可以找出QQ号码:

首先删除第一个数,紧接着将第二个数放到这串数字的末尾,再将第三个数删除,并将第四个数放到这串数字的末尾......

如此循环,知道剩下最后一个数,将最后一个数也删除

按照刚才删除的顺序,把这些数字连在一起就是女神的QQ号码啦。

java代码如下:

import java.util.LinkedList;
import java.util.Queue;

public class Yule {
private String QQ;

public Yule(String qQ) {
this.QQ = qQ;
}

public String getQQ() {
return QQ;
}
public void setQQ(String qQ) {
QQ = qQ;
}

public String getRealQQ(){
StringBuffer sb = new StringBuffer();
int n = 1;
String str1= "";
Queue<String> queue = new LinkedList<String>();

for(int i =0 ;i<QQ.length();i++){
queue.add(String.valueOf(QQ.charAt(i)));
}

while((str1 = queue.poll()) != null){
if(n%2 ==0){
queue.add(str1);
}else{
sb.append(str1);
}
n++;
}
return sb.toString();
}

public static void main(String[] args) {
System.out.println("女神qq号是:"+new Yule("631758924").getRealQQ());
}

}


运行结果是:“女神qq号是:615947283”

结果等于答案。

看看自己的代码,然后再看看别人的代码,总觉的很臃肿,十分渴望能把代码写的精辟一些、优雅一些,但是水平有限。

这次之所以想上首页,原因只有一个,希望看到这篇文章的大神们,能帮我提提建议,如何优化一下代码,非常感谢!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: