C++编程 – 快速查找一个对象

2014-7-6 flyfish

在初始阶段会有大量数据增删改,而后期很少有更改,后期大部分是查询操作。

建立索引,使用排序的vector,使用二分法查找

以用户信息为例

用户信息包括,ID,名字,性别,手机号码

class CGender
{
public:
	enum
	{
		Female=0,
		Male=1,
		NotSpecified=2
	};
};

class CUser
{
public:
	UINT64 m_nID;
	CString m_strName;
	int m_nGender;
	UINT64 m_nPhoneNumber;

};

定义用户列表和索引

typedef std::pair<UINT64,std::shared_ptr<CUser>> USER;

建立针对用户操作的引擎

插入

根据ID查看是否存在该用户

根据ID查找用户

class CUserEngine
{
public:

	static std::vector<USER> m_vecUser;
	static void InsertUser(std::shared_ptr<CUser> p);
	static bool IsExist(UINT64 nID);
	static std::shared_ptr<CUser> QueryUserByID(UINT64 nID);

};

实现插入

//小ID在前
bool UserIDSort (const USER& a, const USER& b)
{
	return (a.first < b.first);
}

void CUserEngine::InsertUser(std::shared_ptr<CUser> p)
{
	m_vecUser.push_back(USER(p->m_nID,p));
	std::sort(m_vecUser.begin(),m_vecUser.end(),UserIDSort);

}

实现查找用户

struct UserIDCompare
{
	bool operator()(USER user, UINT64 nID) const
	{
		return user.first < nID;
	}
	bool operator()(UINT64 nID, USER user) const
	{
		return nID < user.first;
	}
};
bool CUserEngine::IsExist(UINT64 nID)
{
	return std::binary_search(m_vecUser.begin(),m_vecUser.end(),nID,UserIDCompare());
}

std::shared_ptr<CUser> CUserEngine::QueryUserByID(UINT64 nID)
{
	std::shared_ptr<CUser>p=nullptr;

	std::vector<USER>::iterator iter=std::lower_bound(m_vecUser.begin(),m_vecUser.end(),nID,UserIDCompare());
	if (iter!=m_vecUser.end() && !(UserIDCompare()(nID,*iter)))
	{
		p=(*iter).second;
	}
	return p;

}

测试

//随机生成用户信息
std::default_random_engine dre;
std::uniform_int_distribution<int> diGender(CGender::Female,CGender::NotSpecified);
std::uniform_int_distribution<UINT64> diPhoneNUmber(10000000000,19999999999);

for (int i=1;i<10;i++)
{
	std::shared_ptr<CUser> p(new CUser());
	p->m_nID=i;
	p->m_nGender=diGender(dre);
	p->m_nPhoneNumber=diPhoneNUmber(dre);
	CUserEngine::InsertUser(p);
}
for each(auto e in CUserEngine::m_vecUser)
{
	//输出用户信息
}

if(CUserEngine::IsExist(5))
{
	//查找是否存在ID为5的用户
}
std::shared_ptr<CUser> p=CUserEngine::QueryUserByID(3);
if (nullptr!=p)
{
	//输入ID为3的用户信息
}

以上程序在win7+VC++2010下调试通过

C++编程 – 快速查找一个对象

时间: 2024-10-07 17:24:10

C++编程 – 快速查找一个对象的相关文章

C++编程 – 高速查找一个对象

2014-7-6 flyfish 在初始阶段会有大量数据增删改.而后期非常少有更改,后期大部分是查询操作. 建立索引.使用排序的vector,使用二分法查找 以用户信息为例 用户信息包含,ID.名字,性别,手机号码 class CGender { public: enum { Female=0, Male=1, NotSpecified=2 }; }; class CUser { public: UINT64 m_nID; CString m_strName; int m_nGender; UI

bash编程快速入门

首先,我们简单的介绍一下bash,bash是GNU计划编写的Unixshell,它是许多Linux平台上的内定shell,它提供了用户与系统的很好的交互,对于系统运维人员,bash的地位是举足轻重的,bash编程能很快处理日常的任务 bash入门,一个最简单的bash例子 #vim hello.sh #!/bin/bash #This is the first example of the bash #echo "Hello world" 下面,我们就这个简单的bash 脚本来介绍一下

《Python编程快速上手 让繁琐工作自动化》pdf

<div id="article_content" class="article_content tracking-ad" data-mod="popu_307" data-dsm="post"> <p><br></p><p>下载地址:<a target="_blank" href="https://page74.ctfile.co

Java中Map相关的快速查找算法与唯一性(转载)

原文地址:http://blog.csdn.net/chuyuqing/article/details/19629229 在对<Set和hashCode()>的一篇原创文章写完后,由于对自己的一些论断产生了模糊和怀疑,因此又对Set进行了一些研究,形成本篇. 在Set的使用场景中,我们不外乎看中了她存储数据的唯一性,即不能存储重复值,这在某些应用场合下是很必要的一个特性.那么从更深一层来考虑,Set究竟如何使数据不重复的呢?从另一个层面来考虑,她又如何确保在验证数据是否重复过程中的快速性呢?假

《算法C语言实现》————快速-查找算法(quick-find algorithm)

算法基础是一个整型数组,当且仅当第p个元素和第q个元素相等时,p和q时连通的.初始时,数组中的第i个元素的值为i,0<=i<N,为实现p与q的合并操作,我们遍历数组,把所有名为p的元素值改为q.我们也可以选择另外一种方式,把所有名为q的元素改为p. 这个程序从标准输入读取小于N的非负整数对序列(对p-q表示"把对象β 连接到q"),并且输出还未连通的输入对.程序中使用数组id,每个元素表示一个对象,且具有以下性质,当且仅当p和q时连通的,id[p]和id[q]想等.为简化起

Python编程快速上手-让繁琐工作自动化-第二章习题及其答案

Python编程快速上手-让繁琐工作自动化-第二章习题及其答案 1.布尔数据类型的两个值是什么?如何拼写? 答:True和False,使用大写的T和大写的F,其他字母是小写. 2.3个布尔操作符是什么? 答:and.or和not. 3.写出每个布尔操作符的真值表(也就是操作数的每种可能组合,以及操作的结果) 答:and:True and True  -> True True and False -> FalseFalse and True -> FalseFasle and False

Python编程快速上手 让繁琐工作自动化 云图

图书封面 本书简介 本书的第一部分介绍了基本 Python 编程概念,第二部分介绍了一些不同的任务,你可以让计算机自动完成它们.第二部分的每一章都有一些项目程序,供你学习.下面简单介绍一下每章的内容.第一部分: Python 编程基础"第 1 章: Python 基础"介绍了表达式. Python 指令的最基本类型,以及如何使用 Python 交互式环境来尝试运行代码."第 2 章:控制流"解释了如何让程序决定执行哪些指令,以便代码能够智能地响应不同的情况.&quo

Python编程快速上手 让繁琐工作自动化pdf

[下载地址] 如今,人们面临的大多数任务都可以通过编写计算机软件来完成.Python是一种解释型.面向对象.动态数据类型的高级程序设计语言.通过Python编程,我们能够解决现实生活中的很多任务. 本书是一本面向实践的Python编程实用指南.本书的目的,不仅是介绍Python语言的基础知识,而且还通过项目实践教会读者如何应用这些知识和技能.本书的首部分介绍了基本Python编程概念,第二部分介绍了一些不同的任务,通过编写Python程序,可以让计算机自动完成它们.第二部分的每一章都有一些项目程

Python 编程快速上手 让繁琐工作自动化-第十一章实践项目 11.11.1命令行邮件程序

11.11.1 命令行邮件程序 编写一个程序,通过命令行接受电子邮件地址和文本字符串.然后利用selenium登录到你的邮件账号,将该字符串作为邮件,发送到提供的地址(你也许希望为这个程序建立一个独立的邮件账号).这是为程序添加通知功能的一种好方法.你也可以编写类似的程序,从Facebook 或Twitter 账号发送消息.这个项目弄了好几天,头都快炸了,终于弄好了代码如下:#!/usr/bin/env python#encoding:utf-8 '''@author:Kevinbr/>@aut