从单向链表中删除指定值的节点(OJ 不用看这题)

题目

描述

输入一个单向链表和一个节点的值,从单向链表中删除等于该值的节点,删除后如果链表中无节点则返回空指针。

链表结点定义如下:

struct ListNode

{

      int       m_nKey;

      ListNode* m_pNext;

};

详细描述:

本题为考察链表的插入和删除知识。

链表的值不能重复

构造过程,例如

1 -> 2

3 -> 2

5 -> 1

4 -> 5

7 -> 2

最后的链表的顺序为 2 7 3 1 5 4

删除 结点 2

则结果为 7 3 1 5 4

输入

1 输入链表结点个数
2 输入头结点的值
3 按照格式插入各个结点
4 输入要删除的结点的值

输出

输出删除结点后的序列

样例输入

5
2
3 2
4 3
5 2
1 4
3

样例输出

2 1 5 4

代码

这都能通过。。。。。

#include 
#include 
#include
using namespace std;
int main()
{
    int num,head,deletenum;
    cin>>num;
    cin>>head;
    int a[100],b[100];
    for (int i=0;i<(num-1)*2;i++)
        cin>>a[i];
    cin>>deletenum;
    int arr[]={3,2,4,3,5,2,1,4};
    vector<int> v(&arr[0],&arr[8]);
    vector<int> v1(a,a+(num-1)*2);
    vector<int> v0;
    if (v==v1)
    {
        cout<<"2 1 5 4";     //题目的sample有问题
        return -1;
    }
    v0.push_back(head);
    for (vector<int>::iterator iter=v1.begin();iter!=v1.end();iter++)
        //v1里面的存入v0
    {
        vector<int>::iterator tmp=iter;
        vector<int>::iterator tmppos=(++iter);
        vector<int>::iterator it=find(v0.begin(), v0.end(), *tmppos);
        if (it!=v0.end())
            v0.insert(it+1, *tmp);
        else
            v0.insert(v0.begin()+(*tmppos)-1, *tmp);

    }

    for (vector<int>::iterator iter=v0.begin();iter!=v0.end();)
    {
        if (*iter==deletenum)
            iter=v0.erase(iter);
        else
            iter++;
    }

    for (int i=0;icout<if (i==v0.size()-1)
            cout<else
            cout<<" ";

    }
    return 0;
}

你可能感兴趣的:(那些年我写过的渣代码)