目录大全 免费收录各类优秀网站,快速提升网站流量,支持QQ登录,立即快审业务。
友情提示:本站支持 QQ一键登录、积分扫码充值、网站自助快审、文章自助快审。 注:不接受非法网站和文章。
您现在的位置:首页 > 站长咨询 > 互联网 > 文章内容 > 找程序员女神要QQ号码

找程序员女神要QQ号码

作者:网址目录123 发布时间:2017-02-04 00:21 浏览:

是这样子滴

想法是美好的,现实是残酷的,找女神要QQ号码的时候,没想到女神没有直接给我,而是给了我出了道题(果真是程序员的交手~~ ~),题都给我了,做不出来的话,不但没了和女神的接触机会,连赖以为生的基本技能——编程能力都被质疑了~~~题目是这样的:

给了一串数字(不是QQ号码),根据下面规则可以找出QQ号码:首先删除第一个数,紧接着将第二个数放到这串数字的末尾,再将第三个数删除,并将第四个数放到这串数字的末尾……如此循环,知道剩下最后一个数,将最后一个数也删除,按照刚才删除的顺序,把这些数字连在一起就是女神的QQ号码啦。


就是这样,女神给了一串数字1872278,现在要做的就是从这个数字中找出女神的QQ号码了,方法有很多种,比如说用9张卡片分别写上这9个数字,模拟题目的过程,可以算出来,也可以用笔一个一个的去算~~~~

这些方法都太low了,显示不出程序员的能力,还是写个程序比较酷一点(其实我是在想,要是下次再遇到一个女神出这样的题目,程序就很方便了,哈哈~~~)

解决办法

第一种方法,采用数学的方法,根据题目的规律,循环下面的操作:取整=>取余=>取余*10+取整。。。。。取余取整的对象都是10的倍数,根据位数而定,每次取整之后就是一位,循环直到数字等于0。

<?php  
$raw_num = 1872278;  $num = 0;  $devisor = 1;  while($devisor < $raw_num)  {  
    $devisor *= 10;     //获取最小的大于raw_num的10的倍数的整数  }  while ($raw_num > 0) {  
    $devisor /= 10;  
    $next = floor($raw_num / $devisor); //获取下一个数字  
    $num = $num*10 + $next;             //计算”半成品“QQ号码  
    $raw_num = $raw_num % $devisor;  
    $last = floor($raw_num * 10 / $devisor);    //移动数字,拼接最新的QQ号码  

    $pre = $raw_num % (ceil($devisor / 10));  

    $raw_num = $pre * 10 + $last;     }  echo "恭喜你啦,成功获取QQ号码:{$num}";    //恭喜你啦,成功获取QQ号码:1872278

利用队列的FIFO获取QQ号码,根据题目的特性,刚好可以使用队列来处理,队列简单方便,而且更好理解。

#include<stdio.h> struct queue {  
    int *data;  
    int head;  
    int tail;  };   int main()  {  
    int num, i;  
    printf("请输出要破译的QQ号码长度:");  
    scanf("%d", &num);  

    struct queue q;  
    q.data = (int *)malloc(sizeof(int)*(num*2-1));  //总共需要的数组长度为num*2-1       q.head = 0;  
    q.tail = 0;  

    for(i=1;i<=num;i++)  
    {  
        scanf("%d", &q.data[q.tail]);  
        q.tail++;  
    }  

    printf("恭喜你啦,成功获取QQ号码:");   
    while(q.head < q.tail)  
    {  
        printf("%d", q.data[q.head]);  
        q.head++;  

        q.data[q.tail] = q.data[q.head];  
        q.tail++;  
        q.head++;  
    }  
    return 0;  }  #下面是一个实验  请输出要破译的QQ号码长度:1872278 恭喜你啦,成功获取QQ号码:82428271请按任意键继续. . .

恭喜你啦,成功获取QQ号码:1872278请按任意键继续. . .

说点啥

————————————分割线————————————
21楼@逐影的js用了数组的push、shift也不错(略有修改),”先push后shift“:

var n = "1872278";  var arr = [];  var res = [];  for(var i=0; i<n.length; i++) {  
    arr.push(n.charAt(i));  }  while(arr.length) {  
    if(arr.length !== 1) {  
        res.push( arr.shift() );  
        arr.push( arr.shift() );      
    } else {  
        res.push( arr.shift() );  
    }  }     
console.log(res.join('')); //1872278


    (0)

    有用!

    100%
    (0)

    无用!

    100%
    关键词: 程序员,技能,能力,数学

    评论一下