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

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

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

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

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

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

 

“找女神要QQ号码”——跟风篇java新手版(求指点)_第1张图片

 

题目就是这样的:

给了一串数字(不是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” 

结果等于答案。

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

这次之所以想上首页,原因只有一个,希望看到这篇文章的大神们,能帮我提提建议,如何优化一下代码,非常感谢!

 

你可能感兴趣的:(java)