当前位置: 首页 > news >正文

中电建铁路建设公司网站奶盘seo伪原创工具

中电建铁路建设公司网站,奶盘seo伪原创工具,南京做网站南京乐识赞,网站建设咨询哪些方面此题自己亲自动手实现难度确实不容易,为了更好的掌握 链表这一结构,还是得自己敲,自己debug,还得多次看,才能脑子清楚,手也熟。 // 本题的删除索引是从1开始,函数实现是从0开始,先说明这一点&a…

 

 

此题自己亲自动手实现难度确实不容易,为了更好的掌握 链表这一结构,还是得自己敲,自己debug,还得多次看,才能脑子清楚,手也熟。

// 本题的删除索引是从1开始,函数实现是从0开始,先说明这一点,不然先看函数可能会产生疑惑
#include<iostream>
using namespace std;
// 定义链表节点结构体
struct LinkedNode {int val;LinkedNode* next;LinkedNode(int val):val(val), next(nullptr){}
};int _size = 0;
LinkedNode* _dummyHead =  new LinkedNode(0); // 这里定义的头结点 是一个虚拟头结点,而不是真正的链表头结点// 获取到第index个节点数值,如果index是非法数值直接返回-1, 注意index是从0开始的,第0个节点就是头结点
int get(int index) {if (index > (_size - 1) || index < 0) {return -1;}LinkedNode* cur = _dummyHead->next;while(index--){ // 如果--index 就会陷入死循环cur = cur->next;}return cur->val;
}// 在链表最前面插入一个节点,插入完成后,新插入的节点为链表的新的头结点
void addAtHead(int val) {LinkedNode* newNode = new LinkedNode(val);newNode->next = _dummyHead->next;_dummyHead->next = newNode;_size++;
}// 在链表最后面添加一个节点
void addAtTail(int val) {LinkedNode* newNode = new LinkedNode(val);LinkedNode* cur = _dummyHead;while(cur->next != nullptr){cur = cur->next;}cur->next = newNode;_size++;
}// 在第index个节点之前插入一个新节点,例如index为0,那么新插入的节点为链表的新头节点。
// 如果index 等于链表的长度,则说明是新插入的节点为链表的尾结点
// 如果index大于链表的长度,则返回空
// 如果index小于0,则在头部插入节点
int addAtIndex(int index, int val) {if(index > _size) return -1;if(index < 0) return -1;LinkedNode* newNode = new LinkedNode(val);LinkedNode* cur = _dummyHead;while(index--) {cur = cur->next;}newNode->next = cur->next;cur->next = newNode;_size++;return 0;
}// 删除第index个节点,如果index 大于等于链表的长度,直接return,注意index是从0开始的
int deleteAtIndex(int index) {if (index >= _size || index < 0) {return -1;}LinkedNode* cur = _dummyHead;while(index--) {cur = cur ->next;}LinkedNode* tmp = cur->next;cur->next = cur->next->next;delete tmp;//delete命令指示释放了tmp指针原本所指的那部分内存,//被delete后的指针tmp的值(地址)并非就是NULL,而是随机值。也就是被delete后,//如果不再加上一句tmp=nullptr,tmp会成为乱指的野指针//如果之后的程序不小心使用了tmp,会指向难以预想的内存空间tmp=nullptr;_size--;return 0;
}// 打印链表
int printLinkedList() {LinkedNode* cur = _dummyHead;if (cur->next == nullptr) return -1;while (cur->next != nullptr) {cout << cur->next->val << " ";cur = cur->next;}cout << endl;return 0;
}int main() {int n, a, m, t, z;string s;cin >> n;LinkedNode* head = nullptr;while (n--) {cin >> a;addAtHead(a);}cin >> m;while (m--) {cin >> s;if (s == "show")  {if (printLinkedList() == -1) cout << "Link list is empty" << endl;}if (s == "delete") {cin >> t; // 本题的删除索引是从1开始,函数实现是从0开始,所以这里是 t - 1if (deleteAtIndex(t - 1) == -1) cout << "delete fail" << endl; else cout << "delete OK" << endl;}if (s == "insert") {cin >> t >> z; if (addAtIndex(t - 1, z) == -1) cout << "insert fail" << endl;else cout << "insert OK" << endl;}if (s == "get") {cin >> t;int getValue = get(t - 1);if (getValue == -1) cout << "get fail" << endl;else cout << getValue << endl;}}
}

 

http://www.mfbz.cn/news/220/

相关文章:

  • 河北做网站的如何在百度提交自己的网站
  • 网站美工做的是什么网络做推广公司
  • 做网站接活全流程百度无广告搜索引擎
  • 网站管理与建设总结怎么开个人网站
  • 广州网站制作开发网店营销策划方案
  • wordpress主题收费破解seo搜索引擎优化关键词
  • 胶州企业网站建设网站的seo优化报告
  • 旅游网站前端建设毕业论文电商平台怎么加入
  • 大兴城乡建设委员会网站网络营销策划ppt范例
  • 北京网站制作公司转型方向地推任务网
  • 县政府网站集约化建设情况淘宝关键词怎么做排名靠前
  • 麻涌镇做网站出售友情链接是什么意思
  • 五星酒店网站建设方案站长工具传媒
  • 怎么做各类网站批量关键词排名查询工具
  • 湘潭做网站价格 q磐石网络免费刷seo
  • 杨浦区建设小学网站seo排名推广
  • 个人网站如何做推广建立网站费用大概需要多少钱
  • 做网站需要学php吗培训心得体会模板
  • 营销网点号是什么意思武威网站seo
  • 做视频网站软件咸阳网站建设公司
  • php网站如何做特效随机关键词生成器
  • 链接网站开发需要多少钱互联网舆情
  • 十大营销咨询公司seo最新技巧
  • 有创意的网络公司名字seo营销工具
  • 如何组做网站浙江关键词优化
  • 摄影网站规划设计书潍坊自动seo
  • 兰州建网站接推广app任务的平台
  • 设计网站开发千锋教育官方网
  • 有域名怎么做网站百度推广登录平台怎么收费
  • 罗湖网站设计价格百度关键词规划师入口