// 有关学生信息的头文件student.h代码如下
#include
#include
using namespace std;
struct Student // 表示学生信息的结构体
{
string id; // 学号
string name; // 姓名
int grade; // 年级
int cls; // 班级
Student(){}
Student( string id, string n, int g, int c ) // 构造函数
: id( id ), name( n ), grade( g ), cls( c )
{ }
friend istream & operator >> ( istream &, Student & ); // 友元输入函数
friend ostream & operator << ( ostream &, const Student &);// 友元输出函数
};
istream &
operator >> ( istream &is, Student &stu ) // 输入函数
{
is >> stu.id;
if( stu.id == "-1" ) // 如果输入学号为-1,则表示结束输入
{
is.setstate( ios_base::failbit ); // 设置输入流状态
return is; // 返回
}
is >> stu.name; // 输入姓名
is >> stu.grade; // 输入年级
is >> stu.cls; // 输入班级
return is; // 返回输入流
}
ostream &
operator << ( ostream &os, const Student &stu) // 输出函数
{
os << stu.id << ' '; // 输出学号
os << stu.name << ' '; // 输出姓名
os << stu.grade << ' '; // 输出年级
os << stu.cls << ' '; // 输出班级
return os; // 返回输出流
}
//////////////////////////////////////////////////////////////////////////
//主程序文件main.cpp代码如下
#include
#include
#include
#include // 包含头文件map
#include "student.h" // 包含学生信息头文件student.h
using namespace std; // 使用名称空间std
typedef map STUDENT_BOOK; // 定义学生名册类型
typedef map::iterator STU_ITER; // 定义学生名册迭代器类型
typedef map::const_iterator CONST_STU_ITER;
// 定义学生名册常量迭代器类型
void outputStudentBook( const STUDENT_BOOK & book )// 输出学生名册的函数
{
CONST_STU_ITER iter = book.begin(); // 定义迭代器,指向容器头
while( iter != book.end() ) // 遍历学生名册
{
cout<< iter->second << endl; // 输出学生信息
iter++;
}
}
int main(int argc, char *argv[]) // 主函数
{
// ——使用map容器管理学生名册——
STUDENT_BOOK stuBook; // 定义学生名册
STU_ITER iter; // 定义学生名册迭代器
cout<<"——建立学生名册——"<<endl;
cout<<"##输入-1退出##"<<endl;
Student stu; // 定义学生信息对象
cin>>stu; // 输入学生信息
while ( cin ) // 输入流状态正确(学号!=-1)
{
stuBook[ stu.id ] = stu; // 插入学生信息
cin>>stu; // 继续输入学生信息
}
cin.clear(); // 恢复输入流状态
cout<<endl<<"——学生名册——"<<endl;
outputStudentBook( stuBook ); // 输出学生名册
cout<<endl<<"——查找学生——"<<endl;
cout<<"##请输入学号,输入-1退出##"<<endl;
string id;
cin>>id; // 输入要查找的学号
while( "-1" != id ) // 学号 != -1
{
iter = stuBook.find( id ); // 查找学生
if( iter == stuBook.end() ) // 如果未找到
{
cout<<"未找到学号为"<<id<<"的记录"<<endl;
}
else
{
cout<<"学生:"<< iter->second <<endl; // 输出学生信息
}
cin>>id; // 继续输入学号
}
cout<<endl<<"——删除学生记录——"<<endl;
cout<<"##请输入学号,输入-1退出##"<<endl;
cin>>id; // 输入要删除的学号
while( "-1" != id ) // 学号 != -1
{
iter = stuBook.find( id ); // 查找学生
if( iter == stuBook.end() ) // 如果未找到
{
cout<<"未找到学号为"<<id<<"的记录"<<endl;
}
else
{
stuBook.erase( id ); // 删除学生信息
}
cin>>id;
}
cout<<endl<<"——学生名册——"<<endl;
outputStudentBook( stuBook ); // 输出学生名册
system("PAUSE");
return EXIT_SUCCESS;
}
- JAVA之旅(二十二)——Map概述,子类对象特点,共性方法,keySet,entrySet,Map小练习
JAVA之旅(二十二)--Map概述,子类对象特点,共性方法,keySet,entrySet,Map小练习 继续坚持下去吧,各位骚年们! 事实上,我们的数据结构,只剩下这个Map的知识点了,平时开发中 ...
- Map(双列集合)
出现的原因:现实生活中有些数据成对存在. 特点:键不可重复,值可以重复. ----------|Map 数据都是以键值对的形式存在,键唯一,值可重复. --------- ...
- []map[][]切片map小计
go中的map我们都知道在进行遍历的时候我们知道他是无序的.对于map[int]interface{}类型的,我们可以通过计算map的长度,通过定长的for循环,进行顺序的输出. 那么如果map的类型 ...
- map 小模板~~~ 写的不好 继续添加
#include<map>#include<string.h>#include<iostream>using namespace std; int main(){ ...
- ArrayList以及Map小练
ArrayList常用方法 public static void main(String[] args) { List list = new ArrayList(); List list1 = new ...
- str 小列题
name = " aleX leNb "#2.有变量 完成如下操作: 移除 name 变量对应的值两边的空格,并输出处理结果 name=name.strip() print(nam ...
- 集合框架-Map集合
* Map集合和Collection集合的区别? * Map集合存储元素是成对出现的,Map集合的键是唯一的,值是可重复的.可以把这个理解为:夫妻对 * Collection集合存储元素是单独出现的, ...
- Map、Debug追踪
Map集合 概述 现实生活中,我们常会看到这样一种集合:IP地址和主机名,身份证号和个人,系统用户名与系统用户对象等,这种一一对应的关系,我们把它称之为映射.Java当中提供了专门的集合类用来 ...
- HashMap为什么效率高?来看看这个小demo
一.前情回顾:在程序中有时候需要存放对象,容器应运而生.容器分为集合和Map.集合在这里不说,说说Map.Map在英语中是地图的意思,这个名字真是起的好,可以让人顾名思义.Map,就是存放键值对的结构 ...
随机推荐
- IO多路复用之select poll epoll
参考文档: http://blog.csdn.net/tennysonsky/article/details/45745887 select(),poll(),epoll()都是I/O多路复用的机制. ...
- FZU Monthly-201909 tutorial
FZU Monthly-201909 tutorial 题目(难度递增) easy easy-medium medium medium-hard hard 思维难度 AB CD EF G H A. I ...
- 冰多多团队-第九次Scrum例会
冰多多团队-第九次Scrum会议 工作情况 团队成员 已完成任务 待完成任务 zpj debug, IAT debug, IAT 牛雅哲 debug, IAT 接通新的语音识别接口和termux,完成 ...
- js控制网页窗口一打开就自动全屏
1.如果不需要开新窗口 在body区加入: <body onLoad= "javascript:window.resizeTo(screen.availWidth,screen.a ...
- 使用Sabaki和Leela Zero配置AI围棋对弈环境
求 李昌镐儿童围棋课堂 的pdf. 一.下载Sabaki和Leela Zero最新版本 二.安装Sabaki 三.安装leela zero 四.Sabaki配置leela zero引擎 五.Sabak ...
- win10-mysql卸载干净
本文介绍,在Windows10系统下,如何彻底删除卸载MySQL 1.停止MySQL服务 开始——所有应用——Windows管理工具——服务,将MySQL服务停止. 2.卸载mysql server ...
- Sword 哈希表
哈希表 哈希表是一种典型的以空间换取时间的数据结构,在没有冲突的情况下,对任意元素的插入.索引.删除的时间复杂度都是O().这样优秀的时间复杂度是通过将元素的key值以hash方法f映射到哈希表中的某 ...
- 中国大互联网公司在github上的开源项目
公司名 账号数 账号名 总项目数 非fork项目数 百度 13 baidu.ApolloAuto. brpc. mipengine.Clouda-team.mesalock-linux. ecomfe ...
- SVM – 核函数
核函数的起源是对于线性不可分的分类情况,其实可以通过p次方多项式,及非线性模型进行分类:然后对于这类非线性多次方的,其实可以按照广义线性模型来进行升维变形,使之成为线性模型,这样就可以放到SVM中来进 ...
- 全基因组关联分析学习资料(GWAS tutorial)
前言 很多人问我有没有关于全基因组关联分析(GWAS)原理的书籍或者文章推荐. 其实我个人觉得,做这个分析,先从跑流程开始,再去看原理. 为什么这么说呢,因为对于初学者来说,跑流程就像一个大黑洞,学习 ...