stl list 正确删除节点程序实例
2013-09-03 16:17
281 查看
#include<stdio.h>
#include<list>
#include<string.h>
using namespace std;
#define ARR_SIZE 20
char * genArr(const char *str)
{
char * arr = new char [ARR_SIZE];
memset(arr, 0, ARR_SIZE);
int len = strlen(str)<ARR_SIZE?strlen(str):ARR_SIZE;
strncpy(arr, str, len);
return arr;
}
list<char *>* genList()
{
list<char *> *mylist = new list<char*>;
mylist->push_back(genArr("I am first"));
mylist->push_back(genArr("I am second"));
mylist->push_back(genArr("I am third"));
mylist->push_back(genArr("I am fourth"));
return mylist;
}
void showList(list<char*> *mylist)
{
if(NULL==mylist || mylist->empty())
{
printf("nothing to show\n");
return;
}
printf("list size is %d\n", mylist->size());
for(list<char *>::iterator it = mylist->begin();it!=mylist->end();it++)
{
printf("%s\n", *it);
}
}
void removeElem(list<char *> * mylist, const char * str)
{
for(list<char*>:: iterator it = mylist->begin();it!=mylist->end();)
{
char *tmp = *it;
printf("before erase %s\n", *it);
if(!strncmp(tmp, str, strlen(str)))
{
//it = mylist->erase(it);
mylist->erase(it++);
printf("after erase %s\n", *it);
delete tmp;
tmp = NULL;
}
else
it++;
}
}
void removeList(list<char *> *mylist)
{
if(NULL==mylist || mylist->empty())
{
printf("nothing to remove \n");
// return;
}
printf("before remove list size is %d, address is %p\n", mylist->size(),mylist);
for(list<char *>::iterator it = mylist->begin();it!=mylist->end();)
{
it = mylist->erase(it);
printf("remove list !!!!!!!\n");
}
printf("after remove list size is %d, address is %p\n", mylist->size(),mylist);
}
int main()
{
list<char *> *mylist = genList();
showList(mylist);
removeElem(mylist,"I am second");
showList(mylist);
removeList(mylist);
showList(mylist);
return 1;
}
#include<list>
#include<string.h>
using namespace std;
#define ARR_SIZE 20
char * genArr(const char *str)
{
char * arr = new char [ARR_SIZE];
memset(arr, 0, ARR_SIZE);
int len = strlen(str)<ARR_SIZE?strlen(str):ARR_SIZE;
strncpy(arr, str, len);
return arr;
}
list<char *>* genList()
{
list<char *> *mylist = new list<char*>;
mylist->push_back(genArr("I am first"));
mylist->push_back(genArr("I am second"));
mylist->push_back(genArr("I am third"));
mylist->push_back(genArr("I am fourth"));
return mylist;
}
void showList(list<char*> *mylist)
{
if(NULL==mylist || mylist->empty())
{
printf("nothing to show\n");
return;
}
printf("list size is %d\n", mylist->size());
for(list<char *>::iterator it = mylist->begin();it!=mylist->end();it++)
{
printf("%s\n", *it);
}
}
void removeElem(list<char *> * mylist, const char * str)
{
for(list<char*>:: iterator it = mylist->begin();it!=mylist->end();)
{
char *tmp = *it;
printf("before erase %s\n", *it);
if(!strncmp(tmp, str, strlen(str)))
{
//it = mylist->erase(it);
mylist->erase(it++);
printf("after erase %s\n", *it);
delete tmp;
tmp = NULL;
}
else
it++;
}
}
void removeList(list<char *> *mylist)
{
if(NULL==mylist || mylist->empty())
{
printf("nothing to remove \n");
// return;
}
printf("before remove list size is %d, address is %p\n", mylist->size(),mylist);
for(list<char *>::iterator it = mylist->begin();it!=mylist->end();)
{
it = mylist->erase(it);
printf("remove list !!!!!!!\n");
}
printf("after remove list size is %d, address is %p\n", mylist->size(),mylist);
}
int main()
{
list<char *> *mylist = genList();
showList(mylist);
removeElem(mylist,"I am second");
showList(mylist);
removeList(mylist);
showList(mylist);
return 1;
}
相关文章推荐
- stl list 正确删除节点程序实例
- 在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误。未找到或无法访问服务器。请验证实例名称是否正确并且 SQL Server 已配置为允许远程连接。 (provider: 命名管道提供程序, error: 40 - 无法打开到 SQL
- Joseph环程序,接受用户输入的Joseph长度Length,开始计数的位置Ini,以及读到第Count个节点时,将该节点从Joseph环中删除,最后输出出环序列。
- ASP.NET 在程序中动态删除、修改配置文件节点值的方法
- JS简单实例之删除增加节点
- javascript操作DOM--添加、删除节点的简单实例
- 删除单链表中的倒数第n个节点的实现及测试程序
- 在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误。未找到或无法访问服务器。请验证实例名称是否正确并且 SQL Server 已配置为允许远程连接。 (provider: 命名管道提供程序, error: 40 - 无法打开到 SQL
- Zookeeper实例原生API--删除节点
- 使用JTree增加,删除,重命名节点,延迟和即时加载树结点完整实例
- Zookeeper实例Curator API-使用Curator删除节点
- windows RAC 删除失败节点,添加节点实例操作文档
- 用PHP程序实现删除目录的三种方法实例
- RAC添加删除节点实例
- linux下利用单链表增加和删除节点实例
- oracle rac 如何正确的删除单个节点的actionlist
- Activti跳过中间节点的helloworld实例程序
- 在与 SQL Server 建立连接时出现与网络相关的或特定于实例的错误。未找到或无法访问服务器。请验证实例名称是否正确并且 SQL Server 已配置为允许远程连接。 (provider: 命名管道提供程序, error: 40 - 无法打开到 SQL
- c++实现二叉树的查找,插入,删除,深度,叶子节点数,度为1的节点数(递归方法)及运行实例结果
- JavaScript DOM节点操作实例小结(新建,删除HTML元素)