03把链表分隔成 k 部分,每部分的长度都应该尽可能相同,排在前面的长度应该大于等于后面的
思路:首先遍历链表得到有效数字的个数,再求出分成k份的余数和每一份的均长,前面的部分长度加1直到余数为零。这样是为了保证长度尽可能相同的同时排在前面的长度大于后面的,例如将长度为5的链表分成三份,余2,每一份长度为1,将余下的加到前面,即[[1+1],[1+1],[1]]。classSolution{publicListNode[]splitListToParts(ListNoderoot,intk){intlen=0;ListNodecur=root;//遍历得出链表的有效数字while(cur!=null){cur=cur.next;len++;}//求出余数intmod=len%k;//等分的长度intsize=len/k;ListNode[]res=newListNode[k];cur=root;for(inti=0;i<k&&cur!=null;i++){res[i]=cur;intcursize=size+(mod-->0?1:0);for(intj=0;j<cursize-1;j++){cur=cur.next;}ListNodenext=cur.next;cur.next=null;cur=next;}returnres;}}
来自:链表算法-链表算法