题解 | #牛群的合并#

牛群的合并

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)

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-08 11:16
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
07-10 11:55
点赞 评论 收藏
分享
06-15 02:05
已编辑
南昌航空大学 数据分析师
Eason三木:你如果想干技术岗,那几个发公众号合唱比赛的经历就去掉,优秀团员去掉,求职没用。然后CET4这种不是奖项,是技能,放到下面的专业技能里或者单独列一个英语能力。 另外好好改改你的排版,首行缩进完全没有必要,行间距好好调调,别让字和标题背景黏在一起,你下面说能做高质量PPT你得展现出来啊,你这简历排版我用PPT做的都能比你做的好。 然后自我评价,你如果要干数据工程师,抗压能力强最起码得有吧。
简历中的项目经历要怎么写
点赞 评论 收藏
分享
今天 16:52
已编辑
门头沟学院 Java
周五投的,流程今天结束
投递地平线等公司7个岗位
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

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