第十六章 新技术的诱惑-《我的黑科技图书馆》
第(1/3)页
杨辰饶有兴趣的打开链接。
跳出了一个注册验证。
杨辰输入自己的手机号,然后,通过微信账号,登陆上去。
进入第一个挑战关卡,一道算法问题。
看了题目,杨辰不由来了兴趣。
求一个字符串中最长不重复子串的长度,这是一道关于大数据的算法的题题。
有点难度,不过,难不倒杨辰。
这一题有两种解法,最简单的办法就是暴力破解法,另一种是巧妙使用指针来求解。
暴力破解法简单粗暴,但是效率太低,用穷举法列出所有可能的结果,然后,根据附加条件进一步筛选符合条件的解。
杨辰不打算使用,而是运用指针法求解,效率更高,但需要对指针有较深理解。
用三个整形maxlength 、start 、end 分别存储最大子串长度、子串起始位置、子串结束,……。
杨辰调出编程工具,接连敲击代码。
很快,杨辰在关卡下方的答案框,粘贴下题目的答案代码窜,点击发送。
没多久,关卡验证了答案,给予通过。
第二道关卡的题目跳出:一个二叉树,求路径之和
看了题目,杨辰眉头一皱,这是一道客户端的算法题,经过一翻思考,他还是有思路将这道题目解出来。
第三题,第四题,……,杨辰一路过关斩将。
一直到了第十关,杨辰被题目难住了,苦苦想不出解题的思路。
有一个很大的整数list,需要求这个list中所有整数的和,如何实现多核并算,计算一个准确结果。
这种算法不在杨辰的掌握之中,杨辰唯一的思路便是,采用多线程(任务),并且还要分割list,每一小块的list采用一个线程(任务)进行计算其和。
那么必须要等待所有的线程(任务)完成之后才能得到正确的结果,可是,要怎么才能保证同一时间获得“所有的线程(任务)完成之后输出的结果?
……
杨辰眉头紧皱,久久想不到这道题目的解体方式。
不过,杨辰在关卡下方看到一个闯关助手,点击那个连接可以获得闯过这道关卡的攻略。
第(1/3)页