关闭 x
IT技术网
    技 采 号
    ITJS.cn - 技术改变世界
    • 实用工具
    • 菜鸟教程
    IT采购网 中国存储网 科技号 CIO智库

    IT技术网

    IT采购网
    • 首页
    • 行业资讯
    • 系统运维
      • 操作系统
        • Windows
        • Linux
        • Mac OS
      • 数据库
        • MySQL
        • Oracle
        • SQL Server
      • 网站建设
    • 人工智能
    • 半导体芯片
    • 笔记本电脑
    • 智能手机
    • 智能汽车
    • 编程语言
    IT技术网 - ITJS.CN
    首页 » 程序人生 »找程序员女神要QQ号码

    找程序员女神要QQ号码

    2015-06-22 00:00:00 出处:ITJS
    分享

    引言

    我们组来了个美女程序员,我心里窃喜,哈哈这下机会来了。我在想怎么下手呢?好吧,还是从QQ号码开始,找到女神要到QQ号,哈哈,我真是个天才~~~

    是这样子滴

    想法是美好的,现实是残酷的,找女神要QQ号码的时候,没想到女神没有直接给我,而是给了我出了道题(果真是程序员的交手~~ ~),题都给我了,做不出来的话,不但没了和女神的接触机会,连赖以为生的基本技能——编程能力都被质疑了~~~题目是这样的:
    给了一串数字(不是QQ号码),根据下面规则可以找出QQ号码:首先删除第一个数,紧接着将第二个数放到这串数字的末尾,再将第三个数删除,并将第四个数放到这串数字的末尾……如此循环,知道剩下最后一个数,将最后一个数也删除,按照刚才删除的顺序,把这些数字连在一起就是女神的QQ号码啦。

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

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

    解决办法

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

    < php  
    $raw_num = 631758924;  
    $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号码:615947283

    利用队列的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号码长度:9  
    6  
    3  
    1  
    7  
    5  
    8  
    9  
    2  
    4  
    恭喜你啦,成功获取QQ号码:615947283请按任意键继续. . .

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

    说点啥

    本文点子来自《啊哈!算法》中的第二章,第一节【解密QQ号——队列】,唯一的插图也截取自本书。

    ————————————分割线————————————

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

    var n = "631758924";  
    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('')); //615947283
    上一篇返回首页 下一篇

    声明: 此文观点不代表本站立场;转载务必保留本文链接;版权疑问请联系我们。

    别人在看

    PNY 推出 CS3250 M.2 NVMe PCIe Gen5 x4 SSD,高端计算新标杆

    富士康承诺在泰米尔纳德邦投资 1500 亿卢比,创造 14,000 个就业机会

    NetApp Insight 2025:NetApp 和 Red Hat 加强协作,利用 Red Hat OpenShift 虚拟化推动 IT 现代化

    2025 年 OCP 全球峰会:Credo 推出 ZeroFlap 光收发器——人工智能网络光学器件的可靠性革命

    Kong 发布 Volcano,一个用于构建 AI 代理的 MCP 原生 SDK

    昂瑞微科创版IPO成功,上峰水泥跨界投资

    AI赋能,场景智变:第16届深圳国际移动电子展引领场景化消费新浪潮

    OpenAI估值5000亿美元,成全球初创公司中的“估值之王”

    战略突破:三菱电机以匠人心态引领功率半导体技术革新

    英伟达5亿美元投资英国自动驾驶初创公司Wayve

    IT头条

    Synology 更新 ActiveProtect Manager 1.1 以增强企业网络弹性和合规性

    00:43

    新的 Rubrik Agent Cloud 加速了可信的企业 AI 代理部署

    00:34

    宇树科技 G1人形机器人,拉动一辆重达1.4吨的汽车

    00:21

    Cloudera 调查发现,96% 的企业已将 AI 集成到核心业务流程中,这表明 AI 已从竞争优势转变为强制性实践

    02:05

    投资者反对马斯克 1 万亿美元薪酬方案,要求重组特斯拉董事会

    01:18

    技术分享

    大型网站的 HTTPS 实践(三):基于协议和配置的优化

    ubuntu下右键菜单添加新建word、excel文档等快捷方式

    Sublime Text 简明教程

    用户定义SQL Server函数的描述

    怎么在windows 7开始菜单中添加下载选项?

    SQL Server 2016将有哪些功能改进?

      友情链接:
    • IT采购网
    • 科技号
    • 中国存储网
    • 存储网
    • 半导体联盟
    • 医疗软件网
    • 软件中国
    • ITbrand
    • 采购中国
    • CIO智库
    • 考研题库
    • 法务网
    • AI工具网
    • 电子芯片网
    • 安全库
    • 隐私保护
    • 版权申明
    • 联系我们
    IT技术网 版权所有 © 2020-2025,京ICP备14047533号-20,Power by OK设计网

    在上方输入关键词后,回车键 开始搜索。Esc键 取消该搜索窗口。