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

一亩三分地论坛

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

[CareerCup] 很简单的链表找环

[复制链接] |试试Instant~ |关注本帖
TonyJang 发表于 2014-9-24 20:22:45 | 显示全部楼层 |阅读模式

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

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

x
进入debug的时候有bug,实在找不到,求助大家

1.Node.java
  1. package Chapter2;

  2. public class Node<T> {
  3. public T data;
  4. public Node<T> next;
  5. public Node(T d, Node<T> n){
  6. data = d;
  7. next = n;
  8. }
  9. }
复制代码
2.MylinkedList.java
  1. package Chapter2;

  2. //Singly Linked List
  3. public class MyLinkedList<T> {
  4. public Node<T> head;

  5. public MyLinkedList(Node<T> h) {
  6. head = h;
  7. }
  8. public MyLinkedList() {
  9. head = null;
  10. }

  11. public MyLinkedList(T[] dataArray) {
  12. if (dataArray == null || dataArray.length <= 0)
  13. return;
  14. head = new Node<>(dataArray[0], null);
  15. Node<T> node = head;
  16. for (int i = 1; i < dataArray.length; i++) {
  17. node.next = new Node<T>(dataArray[i], null);
  18. node = node.next;
  19. }
  20. }

  21. public void print() {
  22. Node<T> cur = head;
  23. while (cur != null) {
  24. System.out.print(cur.data);
  25. if (cur.next != null) {
  26. System.out.print(" -> ");
  27. }
  28. cur = cur.next;
  29. }
  30. System.out.println();
  31. }

  32. public void prepend(T data) {
  33. Node<T> next = head != null ? head.next : null;
  34. head = new Node<T>(data, next);
  35. }

  36. public MyLinkedList<T> reverse() {
  37. if(head == null) return null;
  38. Node<T> newHead = head;
  39. Node<T> cur = head.next;
  40. head.next = null;
  41. while(cur != null) {
  42. Node<T> next = cur.next;
  43. cur.next = newHead;
  44. newHead = cur;
  45. cur = next;
  46. }
  47. head = newHead;
  48. return this;
  49. }
  50. }
复制代码
3.findbegning.java
  1. package Chapter2;

  2. public class findBeginning{

  3. public static<T> Node<T> findBegining(MyLinkedList<T> list){

  4. if(list.head==null||list==null)

  5. return null;

  6. Node<T> fast=list.head;
  7. Node<T> slow=list.head;

  8. while(fast!=null&&fast.next!=null){
  9. slow=slow.next;
  10. fast=fast.next.next;

  11. if(slow==fast) {break;
  12. }

  13. if(fast ==null|| fast.next==null){
  14. return null ;


  15. }
  16. }
  17. slow=list.head;
  18. while(slow!=fast){
  19. slow=slow.next;
  20. fast=fast.next;

  21. }

  22. return fast;
  23. }

  24. public static void main(String[] args){

  25. MyLinkedList<Integer> list=new MyLinkedList<>(new Integer[] {1,2,3,4,5,3});

  26. list.print();
  27. System.out.println(findBegining(list).data);


  28. }

  29. }
复制代码
编译没错误,运行有错,求解答,加大米


smzfeng 发表于 2014-9-26 08:18:04 | 显示全部楼层
MyLinkedList<Integer> list=new MyLinkedList<>(new Integer[] {1,2,3,4,5,3});

我认为这个链表没有环
回复 支持 反对

使用道具 举报

全球28万学生4.7分推荐
 楼主| TonyJang 发表于 2014-9-26 09:53:20 | 显示全部楼层
smzfeng 发表于 2014-9-26 08:18
MyLinkedList list=new MyLinkedList(new Integer[] {1,2,3,4,5,3});

我认为这个链表没有环

是的,我自己写testcase很少,没注意。。。
回复 支持 反对

使用道具 举报

本版积分规则

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

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

关闭

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

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

custom counter

GMT+8, 2018-5-25 05:57

Powered by Discuz! X3

© 2001-2013 Comsenz Inc. Design By HUXTeam

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