2017huas_ACM第三天
暑假集训第三天。
就在刚才AC了第十题,本周做题拿到了满分。
软件工程专业没有学习C++语言,这在做题过程中给了我不少的麻烦。遇到什么不懂的,不确认的,都要上网查阅或者开了新项目自己尝试一下。耗费了不少时间,也走了不少弯路。
用C++已经三天了,因为是做ACM的关系,逻辑都是面向过程的,总的感觉和C语言的区别并不大。
C++的STL提供了很多现成的模板,合理利用这些模板是我现在要攻克的课题。
queue、stack、map、set、vector。这些数据结构什么时候用,怎么用,怎么去选择他们。
经过几天的使用我对他们也有了一些初步的见解:
queue:先入先出,但我一般使用的是其变种优先队列(priority_queue<int>和priority_queue<int,vector<int>,greater<int> >),这两个队列分别可以优先取出最大元素和最小元素。可以猜测其对自定义变量也可使用,只需要重置运算符或做类似前提准备,同时其应该还有更多的优先条件可以选择或自定义。
优先队列给我的感觉像一个随时在用Linq排序的List<>,其push()的方法对应add()等......但我每次只能读取其表头元素内容,对于能否使用索引器[]来访问其他位置的元素暂时还未尝试过。
stack:先入后出,在一些特殊情况时意外的很好用,虽然要达成这个目的逻辑很简单,要手写也能很快写出来,但stack得便捷在于拥有许多定义好了的方法,在需求时可以直接使用而不用再自己定义。
栈和队列很相近,所以在选择时需要思维很清晰,知道自己接下来要写的逻辑是什么,盲目的使用可能会导致选择错误最后需要大规模重构更或是推翻了重写。
map:曾尝试使用过,但没有成功。给我的感觉有点像字典,都是键值对通过key找vale。但两者可用的方法是否相同还有待考证。
在我觉得我需要使用字典时我会考虑使用map。
set:每个元素只会出现一次,使用次数不多,主要使用其方法count()。通常使用时与其他数据结构同步储存(如计算丑数)。
集合给我的感觉像一个可以快速查询数据结构中所有元素的方法(集合中的count()方法),目前每次使用集合都是为了避免在其他数据结构中储存时出现相同元素的现象,故若其他数据结构有count()方法时我将不会使用集合。感觉集合存在的意义不仅仅只有这个,其他意义还等待我的挖掘。
vector:不定长数组,常常代替数组来使用,其拥有的众多方法让我更愿意选择其而非不能点不出方法的数组。
给我的感觉有点像List<>,但又不同于List<>,很常用的一个数据结构。
......
恩,快中午了,吃饭去~
2017huas_ACM第三天的更多相关文章
- 常用 Gulp 插件汇总 —— 基于 Gulp 的前端集成解决方案(三)
前两篇文章讨论了 Gulp 的安装部署及基本概念,借助于 Gulp 强大的 插件生态 可以完成很多常见的和不常见的任务.本文主要汇总常用的 Gulp 插件及其基本使用,需要读者对 Gulp 有一个基本 ...
- 【原】FMDB源码阅读(三)
[原]FMDB源码阅读(三) 本文转载请注明出处 —— polobymulberry-博客园 1. 前言 FMDB比较优秀的地方就在于对多线程的处理.所以这一篇主要是研究FMDB的多线程处理的实现.而 ...
- Jquery的点击事件,三句代码完成全选事件
先来看一下Js和Jquery的点击事件 举两个简单的例子 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN&q ...
- node.js学习(三)简单的node程序&&模块简单使用&&commonJS规范&&深入理解模块原理
一.一个简单的node程序 1.新建一个txt文件 2.修改后缀 修改之后会弹出这个,点击"是" 3.运行test.js 源文件 使用node.js运行之后的. 如果该路径下没有该 ...
- 简谈百度坐标反转至WGS84的三种思路
文章版权由作者李晓晖和博客园共有,若转载请于明显处标明出处:http://www.cnblogs.com/naaoveGIS/ 1.背景 基于百度地图进行数据展示是目前项目中常见场景,但是因为百度地图 ...
- 一起学 Java(三) 集合框架、数据结构、泛型
一.Java 集合框架 集合框架是一个用来代表和操纵集合的统一架构.所有的集合框架都包含如下内容: 接口:是代表集合的抽象数据类型.接口允许集合独立操纵其代表的细节.在面向对象的语言,接口通常形成一个 ...
- 谈谈一些有趣的CSS题目(三)-- 层叠顺序与堆栈上下文知多少
开本系列,讨论一些有趣的 CSS 题目,抛开实用性而言,一些题目为了拓宽一下解决问题的思路,此外,涉及一些容易忽视的 CSS 细节. 解题不考虑兼容性,题目天马行空,想到什么说什么,如果解题中有你感觉 ...
- 如何一步一步用DDD设计一个电商网站(三)—— 初涉核心域
一.前言 结合我们本次系列的第一篇博文中提到的上下文映射图(传送门:如何一步一步用DDD设计一个电商网站(一)—— 先理解核心概念),得知我们这个电商网站的核心域就是销售子域.因为电子商务是以信息网络 ...
- 测试一下StringBuffer和StringBuilder及字面常量拼接三种字符串的效率
之前一篇里写过字符串常用类的三种方式<java中的字符串相关知识整理>,只不过这个只是分析并不知道他们之间会有多大的区别,或者所谓的StringBuffer能提升多少拼接效率呢?为此写个简 ...
随机推荐
- Nyquist–Shannon sampling theorem 采样定理
Nyquist–Shannon sampling theorem - Wikipedia https://en.wikipedia.org/wiki/Nyquist%E2%80%93Shannon_s ...
- appche配置访问限制
1. 禁止访问某些文件/目录增加Files选项来控制,比如要不允许访问 .inc 扩展名的文件,保护php类库:<Files ~ "\.inc$"> Order a ...
- HDU - 2066 一个人的旅行(最短路径)(模板)
d.每组的第一行是三个整数T,S和D,表示有T条路,和草儿家相邻的城市的有S个(草儿家到这个城市的距离设为0),草儿想去的地方有D个: 求D个城市中距离草儿家最近的距离. s.进行1次单源最短路,找出 ...
- 如何制作.a静态库?合成多架构静态库?
08_01静态库 08_02制作静态库 .a 1.新建项目com+shift+n:选择Framework&Library. 2.下一步. 项目名不能为中文. 3.编写代码之后.用真机运行.会自 ...
- 【转】js中15个常用的正则表达式+正则集合
1 用户名正则 //用户名正则,4到16位(字母,数字,下划线,减号) var uPattern = /^[a-zA-Z0-9_-]{4,16}$/; //输出 true console.log(uP ...
- C#即时通讯系统设计与实现(一)
最近学习了一下即时通讯,写了几天了,现在把遇到的问题和得到的心得在这里分享下. 即时通讯,C/S模式,在服务器上架设服务端,服务端是服务形式的,可以设置为开机自启动,客户端进行访问,可以安装在任意一台 ...
- jquery 3D云
http://www.jq22.com/jquery-info1325 http://demo.jq22.com/jquery-cloud-141217202931 下载地址: http://www. ...
- 学习Python到写poc其实没那么难
现在,开始! 0x00 前言 今天刚刚把http://drops.wooyun.org/tips/12751放到收藏夹准备看的,然后又看到题主的这个问题.顺便观摩了1楼大神的博客,我这种炒鸡新手表示很 ...
- bzoj 4584: [Apio2016]赛艇【dp】
参考:https://www.cnblogs.com/lcf-2000/p/6809085.html 设f[i][j][k]为第i个学校派出的赛艇数量在区间j内,并且区间j内共有k个学校的方案数 把数 ...
- thinkphp5.0常遇到的错误
call a member xxxx on null 1.一般是没有继承controller: 2.对象和数组使用错误.