一亩三分地论坛

 找回密码
 获取更多干货,去instant注册!

扫码关注一亩三分地公众号
查看: 1030|回复: 11
收起左侧

新鲜g家电面

[复制链接] |试试Instant~ |关注本帖
EasonS 发表于 2016-2-10 07:25:04 | 显示全部楼层 |阅读模式

2016(1-3月) 码农类 本科 全职@Google - 网上海投 - 技术电面 |Otherfresh grad应届毕业生

注册一亩三分地论坛,查看更多干货!

您需要 登录 才可以下载或查看,没有帐号?获取更多干货,去instant注册!

x
不知道这题地里有没有:Write code to print all pairs of natural numbers. 这题关键是all 讨论一下意思是pretend the program can run forever 所以就有了下面的死循环做法
void printPairs() {
        int candidate = 0;

        while(true) {
                //0,2 1,2
                for (int i=0; i<candidate; i++) {
System.out.println(i, candidate);
}
//2,2
System.out.println(candidate, candidate);
//2,1 2,0
                for (int j=0; j<candidate; j++) {
System.out.println(candidate, j);
}
//increment
candidate ++;
}
}
就这一题 然后就聊问题了 求onsite~~

评分

1

查看全部评分

qetu133 发表于 2016-2-11 00:10:54 | 显示全部楼层
echo33 发表于 2016-2-10 12:27
这个是啥意思啊?

int是64位或者32位,32位最大值是2^32 = 20亿多一点,电脑一秒钟可以执行上百亿次,所以这个program在32位机器上就一秒不到就回overflow,64位也就稍微比32位慢一点而已。要想run forever,就要用‘0’、‘1’、‘2’...‘9’单独的ASCii字符来模拟递增,因为这样才不会有64,32这样的限制,可以达到10^n(n是当前程序可用内存大小以bits为单位再除以8bits,8bits因为ASCii占用8bits),才能一直跑下去。
回复 支持 2 反对 0

使用道具 举报

qetu133 发表于 2016-2-10 10:39:34 | 显示全部楼层
你这个程序就一秒钟就会死,说要run forever应该是指用char的array来模拟integer递增,c++就是vector<char>
回复 支持 反对

使用道具 举报

CrossTheWall 发表于 2016-2-10 11:37:14 | 显示全部楼层
qetu133 发表于 2016-2-10 10:39
你这个程序就一秒钟就会死,说要run forever应该是指用char的array来模拟integer递增,c++就是vector

是啊,这题就是用string来模拟代替long long, 感觉楼主被interviewer阴了
回复 支持 反对

使用道具 举报

echo33 发表于 2016-2-10 12:27:10 | 显示全部楼层
qetu133 发表于 2016-2-10 10:39
你这个程序就一秒钟就会死,说要run forever应该是指用char的array来模拟integer递增,c++就是vector

这个是啥意思啊?
回复 支持 反对

使用道具 举报

zhuyisong 发表于 2016-2-11 00:16:28 | 显示全部楼层
qetu133 发表于 2016-2-11 00:10.1point3acres缃
int是64位或者32位,32位最大值是2^32 = 20亿多一点,电脑一秒钟可以执行上百亿次,所以这个program在32 ...
. visit 1point3acres.com for more.
您好,请问这种题目应该看什么书去准备啊,感觉leetcode并没有涵盖这方面的题
回复 支持 反对

使用道具 举报

echo33 发表于 2016-2-11 00:58:10 | 显示全部楼层
qetu133 发表于 2016-2-11 00:10
int是64位或者32位,32位最大值是2^32 = 20亿多一点,电脑一秒钟可以执行上百亿次,所以这个program在32 ...

zan~~~duoxie~~!
回复 支持 反对

使用道具 举报

 楼主| EasonS 发表于 2016-2-11 01:06:23 | 显示全部楼层
qetu133 发表于 2016-2-11 00:10
int是64位或者32位,32位最大值是2^32 = 20亿多一点,电脑一秒钟可以执行上百亿次,所以这个program在32 ...

你的思路和作风好厉害 但是我问interviewer这是死循环、int也有个limit 对方回答木有关系 let's pretend... 他还介绍了两句big integer类。。。。反正。。
回复 支持 反对

使用道具 举报

 楼主| EasonS 发表于 2016-2-11 02:05:52 | 显示全部楼层
在网上看到了如下enumerator的做法, 简直欺负我读书少,,引用:resource

How can we have an enumeration for all possible pairs of natural numbers, such
as [0,0] [3,7] [98,1153] [3,0] [0,1] [2,1] [75,34] ....?.1point3acres缃
Cantor's enumeration works by first producing all pairs where the sum of the
parts is zero ([0,0]) then producing all pairs where the sum of the parts is.鐣欏璁哄潧-涓浜-涓夊垎鍦
1 ([0,1] [1,0]) then all pairs with a sum of 2 ([0,2] [1,1] [2,0]) then the
threes ([0,3] [1,2] [2,1] [3,0]) and so on and so on. Any possible cair you
care to mention will obviously eventually be reached (the sum of its parts
gives you an idea of how long it will take), and clearly no pair can be produced
twice. It works like this

   struct Enumerate_Pairs
   { Enumerate_Natural_Numbers enum_sum;
     Enumerate_Natural_Numbers enum_first;
.1point3acres缃     string sum, first, second, zero;-google 1point3acres

     Enumerate_Pairs(). 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
     { sum = enum_sum.next();
       zero = sum;. more info on 1point3acres.com
       first = enum_first.next();. 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
       second = sum; }. 鍥磋鎴戜滑@1point 3 acres

     more(). 1point3acres.com/bbs
     { return true; }

     next()
     { string answer = "[";
       answer = answer + first + "," + second + "]";
       if (second == zero)
       { sum = enum_sum.next();
         enum_first.reset();
         first = enum_first.next();
         second = sum; }
       else. 鐣欏鐢宠璁哄潧-涓浜╀笁鍒嗗湴
       { first = enum_first.next();
         second = Enumerate_Natural_Numbers::previous(second); }
       return answer; } };

Notice that the two internal enumerators for natural numbers could be replaced
by any other enumerators and it would still work in the same way. That's why the
slightly mystifying variable "zero" is used - it captures the first thing ever
to come out of an enumerator, so it can serve as the equivalent of "0" for any
. 1point 3acres 璁哄潧set. We can enumerate all possible pairings of C++ programs with data files,
we could even make pairs out of pairs of things, giving lists of any length.. visit 1point3acres.com for more.
回复 支持 反对

使用道具 举报

 楼主| EasonS 发表于 2016-2-11 02:12:49 | 显示全部楼层
其实我觉得g家面我一刚毕业本科应该不会考这种“知识储备” (也可能我见的题目太少/学的太少) 所以我当时确定这题没见过的时候 也确定了要展示出自己get things done的能力 和交流讨论的能力 所以希望没有正确答案 希望能过,,
回复 支持 反对

使用道具 举报

 楼主| EasonS 发表于 2016-2-27 04:11:26 | 显示全部楼层
楼主过啦 春假去onsite
回复 支持 反对

使用道具 举报

bobzhang2004 发表于 2016-3-5 12:02:33 | 显示全部楼层
qetu133 发表于 2016-2-11 00:10
int是64位或者32位,32位最大值是2^32 = 20亿多一点,电脑一秒钟可以执行上百亿次,所以这个program在32 ...

请问写成code是什么样?
回复 支持 反对

使用道具 举报

本版积分规则

请点这里访问我们的新网站:一亩三分地Instant.

Instant搜索更强大,不扣积分,内容组织的更好更整洁!目前仍在beta版本,努力完善中!反馈请点这里

关闭

一亩三分地推荐上一条 /5 下一条

手机版|小黑屋|一亩三分地论坛声明 ( 沪ICP备11015994号 )

custom counter

GMT+8, 2016-12-7 21:17

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

快速回复 返回顶部 返回列表