免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 21128 | 回复: 17
打印 上一主题 下一主题

php找女神要QQ号码 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2015-06-23 14:29 |只看该作者 |倒序浏览
我们组来了个美女程序员,我心里窃喜,哈哈这下机会来了。我在想怎么下手呢?好吧,还是从QQ号码开始,找到女神要到QQ号,哈哈,我真是个天才~~~

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

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


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

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

第一种方法,采用数学的方法,根据题目的规律,循环下面的操作:取整=>取余=>取余*10+取整。。。。。取余取整的对象都是10的倍数,根据位数而定,每次取整之后就是一位,循环直到数字等于0。
  1. <?php
  2. $raw_num = 631758924;
  3. $num = 0;
  4. $devisor = 1;
  5. while($devisor < $raw_num)
  6. {
  7.         $devisor *= 10;                //获取最小的大于raw_num的10的倍数的整数
  8. }

  9. while ($raw_num > 0) {
  10.         $devisor /= 10;
  11.         $next = floor($raw_num / $devisor);        //获取下一个数字
  12.         $num = $num*10 + $next;                                //计算”半成品“QQ号码
  13.         $raw_num = $raw_num % $devisor;
  14.         $last = floor($raw_num * 10 / $devisor);        //移动数字,拼接最新的QQ号码

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

  16.         $raw_num = $pre * 10 + $last;       
  17. }
  18. echo "恭喜你啦,成功获取QQ号码:{$num}";        //恭喜你啦,成功获取QQ号码:615947283
复制代码
利用队列的FIFO获取QQ号码,根据题目的特性,刚好可以使用队列来处理,队列简单方便,而且更好理解。
  1. #include<stdio.h>
  2. struct queue {
  3.         int *data;
  4.         int head;
  5.         int tail;
  6. };
  7. int main()
  8. {
  9.         int num, i;
  10.         printf("请输出要破译的QQ号码长度:");
  11.         scanf("%d", &num);
  12.        
  13.         struct queue q;
  14.         q.data = (int *)malloc(sizeof(int)*(num*2-1));        //总共需要的数组长度为num*2-1
  15.         q.head = 0;
  16.         q.tail = 0;
  17.        
  18.         for(i=1;i<=num;i++)
  19.         {
  20.                 scanf("%d", &q.data[q.tail]);
  21.                 q.tail++;
  22.         }
  23.        
  24.         printf("恭喜你啦,成功获取QQ号码:");
  25.         while(q.head < q.tail)
  26.         {
  27.                 printf("%d", q.data[q.head]);
  28.                 q.head++;
  29.                
  30.                 q.data[q.tail] = q.data[q.head];
  31.                 q.tail++;
  32.                 q.head++;
  33.         }
  34.         return 0;
  35. }
复制代码
  1. #下面是一个实验
  2. 请输出要破译的QQ号码长度:9
  3. 6
  4. 3
  5. 1
  6. 7
  7. 5
  8. 8
  9. 9
  10. 2
  11. 4
  12. 恭喜你啦,成功获取QQ号码:615947283请按任意键继续. . .
复制代码

论坛徽章:
26
2015亚冠之胡齐斯坦钢铁
日期:2015-06-25 21:40:202015亚冠之柏斯波利斯
日期:2015-08-31 17:03:192015亚冠之柏斯波利斯
日期:2015-11-07 13:10:00程序设计版块每日发帖之星
日期:2015-11-10 06:20:00每日论坛发贴之星
日期:2015-11-10 06:20:00程序设计版块每日发帖之星
日期:2015-11-26 06:20:00程序设计版块每日发帖之星
日期:2015-12-02 06:20:00黄金圣斗士
日期:2015-12-07 17:57:4615-16赛季CBA联赛之天津
日期:2015-12-23 18:34:14程序设计版块每日发帖之星
日期:2016-01-02 06:20:00程序设计版块每日发帖之星
日期:2016-01-06 06:20:00每日论坛发贴之星
日期:2016-01-06 06:20:00
2 [报告]
发表于 2015-06-25 22:05 |只看该作者
回复 1# 船头尺
615947283是女神的QQ号码?

   

论坛徽章:
26
2015亚冠之胡齐斯坦钢铁
日期:2015-06-25 21:40:202015亚冠之柏斯波利斯
日期:2015-08-31 17:03:192015亚冠之柏斯波利斯
日期:2015-11-07 13:10:00程序设计版块每日发帖之星
日期:2015-11-10 06:20:00每日论坛发贴之星
日期:2015-11-10 06:20:00程序设计版块每日发帖之星
日期:2015-11-26 06:20:00程序设计版块每日发帖之星
日期:2015-12-02 06:20:00黄金圣斗士
日期:2015-12-07 17:57:4615-16赛季CBA联赛之天津
日期:2015-12-23 18:34:14程序设计版块每日发帖之星
日期:2016-01-02 06:20:00程序设计版块每日发帖之星
日期:2016-01-06 06:20:00每日论坛发贴之星
日期:2016-01-06 06:20:00
3 [报告]
发表于 2015-06-27 16:10 |只看该作者
本帖最后由 substr函数 于 2015-06-27 16:13 编辑

回复 1# 船头尺
找女神要QQ号,
我是在想,其实可以使用python来处理,
python简单方便,而且更好理解。
  1. #!/usr/bin/python2

  2. FAKE = '631758924'
  3. REAL = ''

  4. while FAKE:
  5.     REAL += FAKE[0]
  6.     FAKE = FAKE[2:] + FAKE[1:2]

  7. print REAL

复制代码

论坛徽章:
26
2015亚冠之胡齐斯坦钢铁
日期:2015-06-25 21:40:202015亚冠之柏斯波利斯
日期:2015-08-31 17:03:192015亚冠之柏斯波利斯
日期:2015-11-07 13:10:00程序设计版块每日发帖之星
日期:2015-11-10 06:20:00每日论坛发贴之星
日期:2015-11-10 06:20:00程序设计版块每日发帖之星
日期:2015-11-26 06:20:00程序设计版块每日发帖之星
日期:2015-12-02 06:20:00黄金圣斗士
日期:2015-12-07 17:57:4615-16赛季CBA联赛之天津
日期:2015-12-23 18:34:14程序设计版块每日发帖之星
日期:2016-01-02 06:20:00程序设计版块每日发帖之星
日期:2016-01-06 06:20:00每日论坛发贴之星
日期:2016-01-06 06:20:00
4 [报告]
发表于 2015-07-03 15:04 |只看该作者
回复 1# 船头尺

已经是厉害的不行了
只缺一个找女神了
   

论坛徽章:
0
5 [报告]
发表于 2015-07-04 11:01 |只看该作者
$raw_num = '6,3,1,7,5,8,9,2,4';
$number = explode(',',$raw_num);
$info = array();
while(count($number) > 2){
        $info[] = $number[0];
        array_shift($number);
        $index = array_shift($number);
        array_push($number,$index);
}
array_push($info,$number[0],$number[1]);
echo implode('', $info);

论坛徽章:
0
6 [报告]
发表于 2015-07-04 11:01 |只看该作者
$raw_num = '6,3,1,7,5,8,9,2,4';
$number = explode(',',$raw_num);
$info = array();
while(count($number) > 2){
        $info[] = $number[0];
        array_shift($number);
        $index = array_shift($number);
        array_push($number,$index);
}
array_push($info,$number[0],$number[1]);
echo implode('', $info);

论坛徽章:
0
7 [报告]
发表于 2015-07-06 09:41 |只看该作者
<script >
var number=new Array(6,3,1,7,5,8,9,2,4);
var newArray=new Array();
var i=0;
while(i<=number.length)
{
        newArray.push(number[i]);
        number.push(number[i+1]);
        i+=2;
}
alert(newArray)
</script>

论坛徽章:
59
2015七夕节徽章
日期:2015-08-24 11:17:25ChinaUnix专家徽章
日期:2015-07-20 09:19:30每周论坛发贴之星
日期:2015-07-20 09:19:42ChinaUnix元老
日期:2015-07-20 11:04:38荣誉版主
日期:2015-07-20 11:05:19巳蛇
日期:2015-07-20 11:05:26CU十二周年纪念徽章
日期:2015-07-20 11:05:27IT运维版块每日发帖之星
日期:2015-07-20 11:05:34操作系统版块每日发帖之星
日期:2015-07-20 11:05:36程序设计版块每日发帖之星
日期:2015-07-20 11:05:40数据库技术版块每日发帖之星
日期:2015-07-20 11:05:432015年辞旧岁徽章
日期:2015-07-20 11:05:44
8 [报告]
发表于 2015-07-10 10:04 |只看该作者
关键是你确定你找到的QQ号后面真的是一美女吗?

论坛徽章:
26
2015亚冠之胡齐斯坦钢铁
日期:2015-06-25 21:40:202015亚冠之柏斯波利斯
日期:2015-08-31 17:03:192015亚冠之柏斯波利斯
日期:2015-11-07 13:10:00程序设计版块每日发帖之星
日期:2015-11-10 06:20:00每日论坛发贴之星
日期:2015-11-10 06:20:00程序设计版块每日发帖之星
日期:2015-11-26 06:20:00程序设计版块每日发帖之星
日期:2015-12-02 06:20:00黄金圣斗士
日期:2015-12-07 17:57:4615-16赛季CBA联赛之天津
日期:2015-12-23 18:34:14程序设计版块每日发帖之星
日期:2016-01-02 06:20:00程序设计版块每日发帖之星
日期:2016-01-06 06:20:00每日论坛发贴之星
日期:2016-01-06 06:20:00
9 [报告]
发表于 2015-07-10 17:35 |只看该作者
回复 7# huangdongcheng

可以
   

论坛徽章:
26
2015亚冠之胡齐斯坦钢铁
日期:2015-06-25 21:40:202015亚冠之柏斯波利斯
日期:2015-08-31 17:03:192015亚冠之柏斯波利斯
日期:2015-11-07 13:10:00程序设计版块每日发帖之星
日期:2015-11-10 06:20:00每日论坛发贴之星
日期:2015-11-10 06:20:00程序设计版块每日发帖之星
日期:2015-11-26 06:20:00程序设计版块每日发帖之星
日期:2015-12-02 06:20:00黄金圣斗士
日期:2015-12-07 17:57:4615-16赛季CBA联赛之天津
日期:2015-12-23 18:34:14程序设计版块每日发帖之星
日期:2016-01-02 06:20:00程序设计版块每日发帖之星
日期:2016-01-06 06:20:00每日论坛发贴之星
日期:2016-01-06 06:20:00
10 [报告]
发表于 2015-07-10 17:38 |只看该作者
回复 8# renxiao2003

是关键
现实是残酷的
   
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP