题解 | #牛群的合并#

牛群的合并

https://www.nowcoder.com/practice/d0cb24e1494e4f45a4b7d1a17db0daef

/**
 * struct ListNode {
 *	int val;
 *	struct ListNode *next;
 * };
 */
/**
 * 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
 *
 * 
 * @param lists ListNode类一维数组 
 * @param listsLen int lists数组长度
 * @return ListNode类
 */
int ListsAllNull(struct ListNode** lists, int listsLen)
{
    int num=0;
    for(int i=0;i<listsLen;i++)
    {
        if(!lists[i])
            num++;
    }
    return num==listsLen?0:1;    
}
struct ListNode* mergeKLists(struct ListNode** lists, int listsLen ) {
    // write code here
    struct ListNode** p=lists;
    struct ListNode* p1=NULL;
    struct ListNode* head=(struct ListNode*)malloc(sizeof(struct ListNode*));
    struct ListNode* p2=head;
    while (ListsAllNull(p,listsLen)) {
        p1=p[0];
        int f=0;
        for(int i=0;i<listsLen-1;i++){
            //求得当前所指最小值,并把p1指针指向该节点
            int num1=-1,num2=-1;
            num1=p1?p1->val:5001;
            num2=p[i+1]?p[i+1]->val:5001;
            p1=num1>num2?p[i+1]:p1;
            f=num1>num2?i+1:f;
        }
        p[f]=p[f]->next;
        p1->next=NULL;
        p2->next=p1;
        p2=p2->next;
    }
        //该节点指向空,接在head链表
        return head->next;
}

C语言,时间复杂度O(n),空间复杂度o(1)

全部评论

相关推荐

大方的大熊猫准备进厂:1.教育背景:你希望从事什么专业的工作你的主修课就是什么;成绩优秀是你应该做的,没什么可描述的,成绩不优秀也许人家在大学忙着创业呢?(成绩优秀不一定是好事,只能说明多元化的大学你上成了高中,没有真正上明白大学,反而体现了你死板,不爱社交,没有别的突出能力) 2.实践经历:你想表达的意思没有说清楚。你是说你会个性化服务,还是你有实习经历。如果没有带来,经济收益,表彰,更好的发展前景,那你还不如说说提升了自己哪些技能。你说有人给你送锦旗我都能明白你优秀,但是你说你会xxxx,你说这话谁信,证据呢。 3.入伍经历:你描述的就是你的工作职责或者你应该做的,并没有体现出来你把这个事情做好了,而且入伍经历并不能证明你能干好你要应聘的工作,不如只写经历其余所有内容都不写。 4.荣誉技能:重点突出一下,但不要过多描述,这些荣誉的含金量懂得都懂。 重点:你要应聘什么工作(具体岗位,实习生不具体),你的期望薪资
点赞 评论 收藏
分享
05-29 20:34
门头沟学院 C++
KarlAllen:得做好直接春招的准备。学历差的话,一是面试要求会比学历好的严格不少,二是就算面试通过了也会被排序。总之暑期和秋招对于学历差的就是及其不友好
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务