[八我司] 介绍一下Uber tech stack和各个大组的情况

一亩三分地论坛

 找回密码
 Sign Up 注册获取更多干货
E轮2.5亿美元融资
K12教育独角兽一起作业
北京-诚聘人工智能/教育/大数据岗
坐标湾区
Games Startup
招聘游戏开发工程师
游戏初创公司招聘工程师、UIUX Designer和游戏策划
码农求职神器Triplebyte:
不用海投
内推多家公司面试
把贵司招聘信息放这里
查看: 4630|回复: 3
收起左侧

Two Sigma OA

[复制链接] |试试Instant~ |关注本帖
qunchen1 发表于 2016-1-10 17:40:23 | 显示全部楼层 |阅读模式

2016(1-3月) 码农类General 博士 全职@TwoSigma - 猎头 - 在线笔试  | Other | 在职跳槽

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

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

x
OA 5 minutes ago.  Still
http://www.1point3acres.com/bbs/ ... adio%26sortid%3D311
. 1point 3acres 论坛
All tests passed


static int friendCircles(String[] friends) {
               
                if ( null == friends || 0 == friends.length ) return 0;. 留学申请论坛-一亩三分地

                int n = friends.length;
               
                //queue and visited flag for BFS
                Queue<Integer> queue = new LinkedList<Integer>();. From 1point 3acres bbs
                boolean[] visited = new boolean[n];
                //min-heap holds the next friend to process at top
                PriorityQueue<Integer> remaining = new PriorityQueue<Integer>();. visit 1point3acres for more.
               
                for (int i = 0; i < n; ++i) {
                        visited = false;
                        remaining.offer(i);. 牛人云集,一亩三分地
                }
                来源一亩.三分地论坛.
                //enqueue 0, the first friend
                enqueue(0, queue, visited, remaining);
               
                int circles = 0;. 留学申请论坛-一亩三分地
                while (true) {       
                        int cur = queue.poll();
                        char[] friendsOfCur = friends[cur].toCharArray();
                        for (int i = 0; i < n; ++i) {
                                if ('Y' == friendsOfCur && i != cur && !visited) {
                                        enqueue(i, queue, visited, remaining);. 留学申请论坛-一亩三分地
                                }
                        }
                       
                        //Either all done or move to next circle
                        if (queue.isEmpty()) {
                                circles++;
                                //all done, exit the loop
                                if( remaining.isEmpty() ) break;. from: 1point3acres
                                //otherwise pick up the smallest friend that has not been processed
                                enqueue(remaining.peek(), queue, visited, remaining);
                        }
                }
               
                return circles;
        }
        . 一亩-三分-地,独家发布
       
        static private void enqueue(int idx, Queue<Integer> q, boolean[] visited, PriorityQueue<Integer> remaining ){
                q.offer(idx);
                visited[idx] = true;. Waral 博客有更多文章,
                remaining.remove(idx);. 一亩-三分-地,独家发布
        }
. 留学申请论坛-一亩三分地


============================================

.留学论坛-一亩-三分地
static int longest_chain(String[] w) {

                        if (null == w || w.length == 0) return 0;

                        //Index words by length. Key: length, value: set of words with given length
                        //Use TreeMap so that the keys are sorted
                        TreeMap<Integer, Set<String>> wordsByLength = new TreeMap<Integer, Set<String>>();.本文原创自1point3acres论坛

                        for (int i = 0; i < w.length; ++i) {
                                int wordLen = w.length();
                                Set<String> wordsOfLen = wordsByLength.get(wordLen);
                                if (null == wordsOfLen) {
                                        wordsOfLen = new HashSet<String>();
                                        wordsByLength.put(wordLen, wordsOfLen);. visit 1point3acres for more.
                                }
                                wordsOfLen.add(w);
                        }

                        int longest = 1;
.1point3acres网
                        //process the longest word first (using descendingMap). 1point3acres
                        for (Map.Entry<Integer, Set<String>> entry : wordsByLength.descendingMap().entrySet()) {
. more info on 1point3acres                                Set<String> wordsOfLen = entry.getValue();
.1point3acres网                                for (String word : wordsOfLen) {
                                        int chainLenOfTheWord = getChainLenOfTheWord(word, wordsByLength);
                                        longest = Math.max(longest, chainLenOfTheWord);
                                }. 留学申请论坛-一亩三分地
                        }. From 1point 3acres bbs
. 1point3acres
                        return longest;. 留学申请论坛-一亩三分地
                }

                //Make recursive calls.  Remove visited (shorter) words for performance
                static private int getChainLenOfTheWord(String word, Map<Integer, Set<String>> wordsByLength) {

                        if (1 == word.length()) return 1;  //base case

                        int chainLenOfTheWord = 1;
                        for (int i = 0; i < word.length(); ++i) {
                                StringBuilder sb = new StringBuilder(word);
                                sb.deleteCharAt(i);  //delete char at i
                                String shorter = sb.toString();

                                Set<String> wordsOfLen = wordsByLength.get(shorter.length());
                                if (null != wordsOfLen) {
                                        if (wordsOfLen.remove(shorter)) { // remove it, no need to visit it again
                                                int chainLenOfTheShorter = getChainLenOfTheWord(shorter, wordsByLength);. From 1point 3acres bbs
                                                chainLenOfTheWord = Math.max(chainLenOfTheWord, chainLenOfTheShorter + 1);
                                        }
                                }. 一亩-三分-地,独家发布
                        }

                        return chainLenOfTheWord;
                }




zzx04025 发表于 2016-2-21 06:52:44 | 显示全部楼层
lz第一题的解法不是很理解,没有用bfs/dfs么
回复 支持 反对

使用道具 举报

zzx04025 发表于 2016-2-21 06:54:10 | 显示全部楼层
请lz无视, 看懂了,bfs
回复 支持 反对

使用道具 举报

ydzhang12345 发表于 2017-1-10 04:07:35 | 显示全部楼层
感谢楼主分享,好详细!
回复 支持 反对

使用道具 举报

本版积分规则

提醒:发帖可以选择内容隐藏,部分板块支持匿名发帖。请认真读完以下全部说明:

■隐藏内容方法: [hide=200]你想要隐藏的内容比如面经[/hide]
■意思是:用户积分低于200则看不到被隐藏的内容
■可以自行设置积分值,不建议太高(200以上太多人看不到),也不建议太低(那就没必要隐藏了)
■建议只隐藏关键内容,比如具体的面试题目、涉及隐私的信息,大部分内容没必要隐藏。
■微信/QQ/电子邮件等,为防止将来被骚扰甚至人肉,以论坛私信方式发给对方最安全。
■匿名发帖的板块和方法:http://www.1point3acres.com/bbs/thread-405991-1-1.html

关闭

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

手机版|小黑屋|一亩三分地论坛声明

custom counter

GMT+8, 2018-5-25 09:51

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

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