C++ 记录问答 (程序设计)链表插入与删除
admin
2024-03-21 02:58:44
0

题目

(程序设计)链表插入与删除。读入多行命令,每行只有一个命令,根据命令操作链表,输出最后的链表。
append,100 表示在链表的最后增加一个数据为100的节点
insert,10,1234 表示在链表的第10个位置(最前面的位置为0)插入数据为1234的节点
delete,5,1000 表示删除第5个节点,后面可能还有一个多余的数据,程序要跳过此数据
end 表示命令输入结束

输入例子:
append,100
append,101
append,102
append,103
insert,2,1000
delete,1,1000
insert,2,1001
append,1002
end

输出结果:
100 1000 1001 102 103 1002

解答

#include 
#include 
using namespace std;//定义单链表节点
using LNode = struct LNode
{int data;LNode* next;
};
using ElemType = int;
using LinkList = LNode*;//初始化单链表
//带头结点的单链表
bool InitListHead(LinkList& L)
{L = new LNode;if (L == nullptr){return false;}L->next = nullptr;return true;
}//按位序插入  在表L中的第i几个位置插入指定元素e
bool ListInsert(LinkList& L, int i, ElemType e)
{if (i < 1){return false;}LNode* p = L;int j = 0;while (p != nullptr && j < i - 1)  //循环找到i-1节点{p = p->next;j++;}if (p == nullptr){return false;}LNode* s = new LNode;s->data = e;s->next = p->next;p->next = s;return true;
}//删除(带头结点)
bool ListDelete(LinkList& L, int i, ElemType& e)
{if (i < 1){return false;}LNode* p = L;int j = 0;while (p != nullptr && j < i - 1){p = p->next;j++;}if (p == nullptr || p->next == nullptr){return false;}LNode* q = p->next;p->next = q->next;e = q->data;delete q;return true;
}//尾插法
LinkList List_TailInert(LinkList& L, int e)
{if (L == nullptr){L = new LNode;           //建立头结点L->next = nullptr;L->data = e;}else{LNode* r = L;           //r为表尾指针while (r->next != nullptr)r = r->next;LNode* s = new LNode;   // 插入节点if (s == nullptr){return s;}s->data = e;s->next = r->next;r->next = s;}return L;
}/*** @brief 打印*/
void print_list(LinkList& L)
{LinkList temp = L;while (temp != nullptr){std::cout << temp->data << " ";temp = temp->next;}std::cout << std::endl;
}//清空链表
void clearList(LinkList& L)
{LinkList p = L;while (L){L = L->next;//先移动Ldelete p;//再释放pp = L;//再移动p}cout << "链表清空完毕!\n";}int main()
{std::string ch;                // 输入命令int y = 0;                     // 输入结束符LinkList L = nullptr;          // 链表do{std::cout << "************************************" << std::endl;std::cout << "\n\t 输入指令 ";std::cout << "\n 1. append,100 表示在链表的最后增加一个数据为100的节点";std::cout << "\n 2. insert,10,1234 表示在链表的第10个位置(最前面的位置为0)插入数据为1234的节点";std::cout << "\n 3. delete,5,1000 表示删除第5个节点,后面可能还有一个多余的数据,程序要跳过此数据";std::cout << "\n 4. end 表示命令输入结束 \n";std::cout << "************************************" << std::endl;std::cout << "\n输入您的选择: ";std::getline(std::cin, ch);int nRet = -1;nRet = ch.find("append");if (nRet != -1){std::string temp = ch.substr(nRet + 7, ch.size() - 1);int nData = std::atoi(temp.c_str());  // 截取插入数据L = List_TailInert(L, nData);continue;}nRet = ch.find("insert");if (nRet != -1){// insert,10,1234int nSerach = ch.find(",", nRet);                               // 确定第1个 "," 位置int nSerach001 = ch.find(",", nSerach + 1);                     // 确定第2个 "," 位置std::string temp = ch.substr(nSerach + 1, nSerach001 - nSerach - 1);    // 位置          std::string temp1 = ch.substr(nSerach001 + 1, ch.size() - 1);	        // 截取插入数据int nNum = std::atoi(temp.c_str());       // 截取插入数据int nData = std::atoi(temp1.c_str());     // 位置bool isInsertFlag = ListInsert(L, nNum, nData);if (!isInsertFlag){std::cout << "insert error" << std::endl;}else{std::cout << "insert success! ch =[" << ch << "]" << std::endl;}continue;}nRet = ch.find("delete");if (nRet != -1){			// delete,5,1000int nSerach = ch.find(",", nRet);                               // 确定第1个 "," 位置int nSerach001 = ch.find(",", nSerach + 1);                     // 确定第2个 "," 位置std::string temp = ch.substr(nSerach + 1, nSerach001 - nSerach - 1);    // 位置          std::string temp1 = ch.substr(nSerach001 + 1, ch.size() - 1);	        // 截取插入数据int nNum = std::atoi(temp.c_str());       // 截取插入数据int nData = std::atoi(temp1.c_str());     // 位置bool isInsertFlag = ListDelete(L, nNum, nData);if (!isInsertFlag){std::cout << "delete error" << std::endl;}else{std::cout << "delete success! ch =[" << ch << "]" << std::endl;}continue;}nRet = ch.find("end");if (nRet != -1){print_list(L);clearList(L);y = 0;	break;}std::cout << "\n输入有效选项.\n";} while (y != 1);return 0;
}

打印输出

************************************输入指令1. append,100 表示在链表的最后增加一个数据为100的节点2. insert,10,1234 表示在链表的第10个位置(最前面的位置为0)插入数据为1234的节点3. delete,5,1000 表示删除第5个节点,后面可能还有一个多余的数据,程序要跳过此数据4. end 表示命令输入结束
************************************
输入您的选择: append,100
************************************输入指令1. append,100 表示在链表的最后增加一个数据为100的节点2. insert,10,1234 表示在链表的第10个位置(最前面的位置为0)插入数据为1234的节点3. delete,5,1000 表示删除第5个节点,后面可能还有一个多余的数据,程序要跳过此数据4. end 表示命令输入结束
************************************
输入您的选择: append,200
************************************输入指令1. append,100 表示在链表的最后增加一个数据为100的节点2. insert,10,1234 表示在链表的第10个位置(最前面的位置为0)插入数据为1234的节点3. delete,5,1000 表示删除第5个节点,后面可能还有一个多余的数据,程序要跳过此数据4. end 表示命令输入结束
************************************
输入您的选择: append,300
************************************输入指令1. append,100 表示在链表的最后增加一个数据为100的节点2. insert,10,1234 表示在链表的第10个位置(最前面的位置为0)插入数据为1234的节点3. delete,5,1000 表示删除第5个节点,后面可能还有一个多余的数据,程序要跳过此数据4. end 表示命令输入结束
************************************
输入您的选择: insert,1,400
insert success! ch =[insert,1,400]
************************************输入指令1. append,100 表示在链表的最后增加一个数据为100的节点2. insert,10,1234 表示在链表的第10个位置(最前面的位置为0)插入数据为1234的节点3. delete,5,1000 表示删除第5个节点,后面可能还有一个多余的数据,程序要跳过此数据4. end 表示命令输入结束
************************************
输入您的选择: delete,1,400
delete success! ch =[delete,1,400]
************************************输入指令1. append,100 表示在链表的最后增加一个数据为100的节点2. insert,10,1234 表示在链表的第10个位置(最前面的位置为0)插入数据为1234的节点3. delete,5,1000 表示删除第5个节点,后面可能还有一个多余的数据,程序要跳过此数据4. end 表示命令输入结束
************************************
输入您的选择: end
100 200 300

相关内容

热门资讯

近一年涨364%,近两年468... 来源:今晚吃基 今天前海开源的两则公告引起我的注意。 前海开源沪港深乐享生活、前海开源人工智能主题混...
美伊、霍尔木兹海峡,最新消息!... 特朗普称与伊朗的谈判进展顺利,霍尔木兹海峡通航量上升,油价维持弱势震荡。另外,特朗普要求中东多国与以...
原创 刚... 4月21日下午,当宁德时代超级科技日的大屏幕亮起时,台下不少行业人士都愣了一下。宁德时代宣布,备受瞩...
俄罗斯知名巧克力品牌优化增效 【环球时报综合报道】俄罗斯最大巧克力生产商之一“联合糖果”正优化生产。“联合糖果”公司(旗下品牌包括...
三星半导体员工协商达成年均奖金... 但这份协议对三星而言仍可能是一次胜利,因为其奖金总额低于本土竞争对手SK海力士。 三星与曾威胁发起罢...
Google亲手把搜索框做成了... Google I/O 2026开完了。如果你以为这家公司又在炫酷炫技术,那你猜对了一半——另一半是,...
女子把2万多克黄金存珠宝店,金... 浙江杭州的林女士反映,她是做黄金生意的,从2024年7月开始,分48次陆续将22917.462克黄金...
000638,终止上市!9股获... 今日(5月25日),A股三大指数集体收涨,上证指数报收4152.57点,上涨0.96%;深证成指上涨...
原创 人... 人民币这波行情,最戏剧性的一幕发生在5月13日。当天即期收盘价直接砸到6.7905,正式踏进6.7区...
燕文物流、闪回科技、金龙电机、... 每经记者:李旭馗 每经编辑:袁东 |2026年5月26日 星期二| NO.1燕文物流、闪回科技、金龙...
一代互联网招聘神话,破产了 消费赛道雷声滚滚,招聘赛道也未能幸免。 近日,招聘行业再传重磅消息,曾被无数互联网人视作“跳槽圣地”...
字节反击腾讯称“都是卖猪食的,... 澎湃新闻记者 范佳来 实习生 吴亦菲 抖音副总裁李亮辟谣“反击腾讯”。 近日,有传言称腾讯、字节跳动...
国有大型银行板块5月25日涨0... 证券之星消息,5月25日国有大型银行板块较上一交易日上涨0.02%,中国银行领涨。当日上证指数报收于...
金属包装行业的主流发展趋势 绿色环保、智能化生产、高端化与个性化、行业整合及国际化拓展是当前金属包装行业的主要发展趋势。 绿色...
投资也有流量密码?带你了解自由... 风险提示:基金有风险,投资需谨慎。
美债收益率破5%:全球资产定价... 导读 4月美国通胀数据超预期反弹、美联储新主席沃什近期就任、中东地缘冲突推升油价、美国财政赤字高企与...
烁威光电同步完成两轮Pre-A... 【大河财立方消息】近日,北京烁威光电科技有限公司(以下简称“烁威光电”)同步完成两轮合计金额超亿元融...
库克将迎CEO告别演讲,此后转... 5月25日,知名科技记者马克 · 古尔曼发文称,今年苹果全球开发者大会 (WWDC) 将是库克作为苹...
北京集中约谈17家重点平台企业... 据北京市市场监督管理局5月25日消息,为加强平台经济监管,规范6·18期间平台经营行为,近日,北京市...
原创 日... 你是否听过下面这些管理名言:”永远站在顾客的立场思考问题“、”盯住客户,而不是竞争对手“、”比业绩更...