免费注册 查看新帖 |

Chinaunix

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

据说是微软面试题 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2006-12-05 00:45 |显示全部楼层 |倒序浏览
圆圈上顺时针排列着1,2,3,....2000 这2000个数. 从1开始,顺时针隔一个拿走一个(1最先被拿走,下一个是3被拿走). 问最后剩下是哪一个数字.

论坛徽章:
0
2 [报告]
发表于 2006-12-05 06:26 |显示全部楼层
原帖由 lknh17 于 2006-12-5 03:21 发表
1024吗?

不对

论坛徽章:
0
3 [报告]
发表于 2006-12-05 13:26 |显示全部楼层
原帖由 tyc611 于 2006-12-5 13:14 发表
我的想法有点笨,不过也说说,大家集思广益嘛
最初的序列为:1,2, 3, 4, ..., 1999, 2000(总数为偶数)
第一次取掉所有奇数,即剩下(2, 4, 6, ..., 1998, 2000) = 2 * ( 1, 2, 3, ..., 999, 1000)( ...


1952正确

论坛徽章:
0
4 [报告]
发表于 2006-12-06 00:14 |显示全部楼层
原帖由 zwylinux 于 2006-12-6 00:09 发表


这个和约瑟夫问题有什么区别没?


不知道约瑟夫问题啊

论坛徽章:
0
5 [报告]
发表于 2006-12-06 00:19 |显示全部楼层
原帖由 灰色骆驼 于 2006-12-6 00:17 发表
就是约瑟夫环


知道那就没意思了

论坛徽章:
0
6 [报告]
发表于 2006-12-06 16:57 |显示全部楼层
原帖由 xxandxx 于 2006-12-5 20:31 发表
1952

int fun(int n)
{
    int first=1, last=n, i;
    int *b = (int *)malloc(2*n*sizeof(int));

    for (i = 1; i <= n; ++i)
        b = i;
   
    while(last-first != 1) {
     ...


有创意
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP