题解 | #牛牛的链表删除#

牛牛的链表删除

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

#include <iostream>
using namespace std;

struct list{

    int data;
    list *next;
};
list* createlist()
{
    list *head = (list*)malloc(sizeof(list));
    head->next = NULL;
    return head;
}
void addnode(list* head,int data)
{

    list *newnode = (list*)malloc(sizeof(list));
    newnode->data = data;
    newnode->next = NULL;
    list *temp;
    for(temp = head;temp->next!=NULL;temp = temp->next);
    temp->next = newnode;

}
void deletenode(list *head,int n)
{
    list *temp = head;
    if(temp->next == NULL)
    {
        cout<<"no node";

    }
    else if((temp->next->next == NULL) && (temp->next->data == n))
    {
        temp->next = NULL;

    }
    else
    {
        list *temp1 ;
        for(temp1 = temp->next;temp1!=NULL;)
        {
            if(temp1->data == n)
            {
                temp->next = temp1->next;
                temp1 = temp1->next;
            }
            else {
                temp = temp->next;
                temp1 = temp1->next;
            }
        }
    }

    


}

int main() {
   int n;
   cin>>n;
   int deletenum;
   cin>>deletenum;
   int arr[10] = {0};
   for(int i=0;i<n;i++)
   {
        cin>>arr[i];

   }
   list* head = createlist();
   for(int j=0;j<n;j++)
   {

        addnode(head,arr[j]);

   }
   deletenode(head, deletenum);
   list *temp = head;
   while(temp->next!=NULL)
   {
    cout<<temp->next->data<<" ";
    temp = temp->next;
   }
   return 0;
}
// 64 位输出请用 printf("%lld")

全部评论

相关推荐

03-26 13:04
已编辑
电子科技大学 算法工程师
xiaowl:你这个简历“条目上”都比较有深度性,但是实际上面试官又没法很好的评估你是怎么达到很多看上去很厉害的结果的。要避免一些看上去很厉害的包装,比如高效的内存复用策略的表达,如果仅是简单的一些内存共享机制,而且面试上也没有深挖的空间,就不要这样表达。比如,工程化模式本质上可能就是定义了一些abstract class,那也就没特别多值得讲的内容。建议简历上应该侧重那些你花了大量时间和精力解决、研究的问题,不要过分追求“丰富”,而是关注在技术深入度、问题解决能力的表现上。
没有实习经历,还有机会进...
点赞 评论 收藏
分享
鱼专:你没有问题,有问题的是java市场,我有实习经历都捞不到实习,走一步看一步吧
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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