函数题:按序号在链表删除结点
要求实现函数,在带头结点的单链表中删除第i个结点。若i的值非法(太大或太小),则不进行删除操作。
### 函数接口定义:
c++
void Delete(Node* head, int i);
其中参数head是指向单链表头结点的指针(头指针),结点的指针域为next;参数i为待删除的位置。
### 裁判测试程序样例:
c++
#include<iostream>
using namespace std;
struct Node {
int data; // 数据域
Node* next; // 指针域
};
void Delete(Node* head, int i);
void Traverse(Node* head);
Node *Create(int n);
int main() {
int n,i;
while(cin>>n>>i) {
Node *h=Create(n);
Delete(h, i);
Traverse(h);
}
return 0;
}
### 输入样例:
in
5 3 5 4 3 2 1
4 1 1 2 4 5
### 输出样例:
out
5 4 2 1
2 4 5
答案:若无答案欢迎评论
### 函数接口定义:
c++
void Delete(Node* head, int i);
其中参数head是指向单链表头结点的指针(头指针),结点的指针域为next;参数i为待删除的位置。
### 裁判测试程序样例:
c++
#include<iostream>
using namespace std;
struct Node {
int data; // 数据域
Node* next; // 指针域
};
void Delete(Node* head, int i);
void Traverse(Node* head);
Node *Create(int n);
int main() {
int n,i;
while(cin>>n>>i) {
Node *h=Create(n);
Delete(h, i);
Traverse(h);
}
return 0;
}
### 输入样例:
in
5 3 5 4 3 2 1
4 1 1 2 4 5
### 输出样例:
out
5 4 2 1
2 4 5
答案:若无答案欢迎评论