码迷,mamicode.com
首页 > 其他好文 > 详细

编程算法 - 二叉搜索树(binary search tree) 集合(set)和映射(map) 代码(C)

时间:2014-07-21 15:48:15      阅读:190      评论:0      收藏:0      [点我收藏+]

标签:mystra   编程算法   二叉搜索树   集合   映射   

二叉搜索树(binary search tree) 集合(set)和映射(map) 代码(C++)


本文地址: http://blog.csdn.net/caroline_wendy


二叉搜索树(binary search tree)作为常用而高效的数据结构, 标准库中包含实现, 在标准库的集合(set)和映射(map), 均使用.

具体操作代码如下.


代码:

/*
 * main.cpp
 *
 *  Created on: 2014.7.20
 *      Author: spike
 */

/*eclipse cdt, gcc 4.8.1*/

#include <stdio.h>

#include <set>
#include <map>

using namespace std;


int main(void)
{
	set<int> s;
	s.insert(1);
	s.insert(3);
	s.insert(5);

	set<int>::iterator ite;

	ite = s.find(1);
	if (ite == s.end()) puts("not found");
	else puts("found");
	ite = s.find(2);
	if (ite == s.end()) puts("not found");
	else puts("found");

	s.erase(3);
	if (s.count(3) != 0) puts("found");
	else puts("not found");

	for (ite=s.begin(); ite!=s.end(); ++ite) {
		printf("%d ", *ite);
	}
	printf("\n");

	map<int, const char*> m;
	m.insert(make_pair(1, "ONE"));
	m.insert(make_pair(10, "TEN"));
	m[100] = "HUNDRED";

	map<int, const char*>::iterator mite;
	mite = m.find(1);
	puts(mite->second);

	mite = m.find(2);
	if (mite == m.end()) puts("not found");
	else puts(mite->second);

	puts(m[10]);

	m.erase(10);
	for (mite = m.begin(); mite!=m.end(); ++mite) {
		printf("%d: %s; ", mite->first, mite->second);
	}
	printf("\n");

	return 0;
}



输出:

found
not found
not found
1 5 
ONE
not found
TEN
1: ONE; 100: HUNDRED; 



bubuko.com,布布扣




编程算法 - 二叉搜索树(binary search tree) 集合(set)和映射(map) 代码(C)

标签:mystra   编程算法   二叉搜索树   集合   映射   

原文地址:http://blog.csdn.net/caroline_wendy/article/details/38016265

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!