ZBLOG

使用c++代码实现以下要求 在日常生活中,有一些列表,比如待办清单或者歌单,我们经常会遇到一个需求,就是改变项目的顺序。一般来说,我们选中需要移动的条目,然后将它拖到我们想要的位置就可以啦! Pulpit rock 今天我们就使用单链表来实现这样一个功能吧! 先用C++实现含头结点的单链表,然后实现单链表中元素位置的移动。 注意不能改变每个结点包含的数据,必须通过修改指针来实现位置调换。 Input 第一行输入整数 n,表示链表中有n个数据; 第二行依次输入 n个数据,中间用空格分隔; 第...

下面是一个使用C++实现含头结点的单链表,并实现元素位置移动的示例代码:

#include <iostream>
using namespace std;

// 定义链表节点结构体
struct ListNode {
    int data;
    ListNode* next;
};

// 创建链表
ListNode* createList(int n) {
    ListNode* head = new ListNode();
    ListNode* cur = head;
    
    for (int i = 0; i < n; i++) {
        int num;
        cin >> num;
        
        ListNode* newNode = new ListNode();
        newNode->data = num;
        newNode->next = nullptr;
        
        cur->next = newNode;
        cur = cur->next;
    }
    
    return head;
}

// 打印链表
void printList(ListNode* head) {
    if (head == nullptr || head->next == nullptr) {
        return;
    }
    
    ListNode* cur = head->next;
    
    while (cur != nullptr) {
        cout << cur->data << " ";
        cur = cur->next;
    }
    
    cout << endl;
}

// 移动元素位置
void moveElement(ListNode* head, int currentPos, int targetPos) {
    if (currentPos == targetPos || head == nullptr || head->next == nullptr) {
        return;
    }
    
    // 获取待移动的节点和其前一个节点
    ListNode* prevNode1 = nullptr; // 待移动节点的前一个节点
	ListNode* currentNode1 = head; // 待移动节点

	while (currentNode1 != nullptr && currentPos > 0) {
		prevNode1 = currentNode1; 
		currentNode1 = currentNode1->next; 
		currentPos--;
	}
	
	if (currentNode1 == nullptr) {
	    cout << "error" << endl;
	    return;
	}
    
    ListNode* prevNode2 = nullptr; // 目标位置节点的前一个节点
	ListNode* currentNode2 = head; // 目标位置节点

	while (currentNode2 != nullptr && targetPos > 0) {
		prevNode2 = currentNode2; 
		currentNode2 = currentNode2->next; 
		targetPos--;
	}
	
	if (currentNode2 == nullptr) {
	    cout << "error" << endl;
	    return;
	}

    // 移动节点
    if (prevNode1 != nullptr) {
        prevNode1->next = currentNode1->next;
    }
    
    if (prevNode2 != nullptr) {
        prevNode2->next = currentNode1;
    } else {
        head->next = currentNode1;
    }
    
    currentNode1->next = currentNode2;

}

int main() {
	int n, t;
	cin >> n;

	ListNode* head = createList(n);

	cout << "Original list: ";
	printList(head);

	cin >> t;

	for (int i = 0; i < t; i++) {
		int currentPos, targetPos;
		cin >> currentPos >> targetPos;

		moveElement(head, currentPos, targetPos);

		cout << "After move #" << i + 1 << ": ";
		printList(head);
	}

	return 0;
}

这段代码首先会根据输入创建含有头结点的单链表,并打印原始列表。然后,根据输入的移动次数和具体位置,调用 moveElement 函数来实现元素位置的移动。最后,打印每一次移动后的结果。如果发现输入的位置不合法,则输出字符串 “error”。


内容由零声教学AI助手提供,问题来源于学员提问

本站部分文章来源于网络,版权归原作者所有,如有侵权请联系站长删除。
转载请注明出处:https://golang.0voice.com/?id=9338

分享:
扫描分享到社交APP
上一篇
下一篇
发表列表
游客 游客
此处应有掌声~
评论列表

还没有评论,快来说点什么吧~

联系我们

在线咨询: 点击这里给我发消息

微信号:3007537140

上班时间: 10:30-22:30

关注我们
x

注册

已经有帐号?