有序向量的唯一化和无序向量不同,分为低效版和高效版.低效版代码如下: template <typename T> int Vector<T>::uniquify() { int oldSize = _size; int i = 1; while (i < _size) { _elem[i - 1] == _elem[i] ? remove(i) : i++; } return oldSize - _size; } 该算法的正确性在于有序算法中的重复元素必然是紧邻的,所以只要自
看了编程珠玑第二章,这里面讲了三道题目,这里说一下第二题,一维向量旋转算法. 题目:将一个n元一维向量(例数组)向左旋转i个位置. 解决方法:书上讲解了5种方法,自己只想起来2种最简单方法(下面讲的前两种). 1.原始方法. 从左向右依次移动一位,对所有数据平移:这样循环i次,算法最坏时间复杂度达n^2.耗时不推荐. 2.空间换时间. 顾名思义,申请一个i长度的空间,把前i半部分放到申请空间中,再把后面的所有数据向左移动i个位置,最后把申请的空间中的数据放到后半部分.浪费空间,不推荐. 3.杂技
声明:本文是对 xuetangx 清华大学 丁俊晖 老师 数据结构 课程的个人总结. 说到有序向量的查找算法,首先蹦入脑海的肯定是二分查找算法. 然而,即便是简单的二分查找也没有想象的那么简单. 首先考虑一些特殊情形: 1.查找的元素不存在: 2.要查找的元素值存在多个. 当然,对于不存在的情况,我们可以简单的返回一个 -1 代表未查找到,但很多时候,这样做往往是不够的.比如说,我们在调用查找之后,很有可能紧接着需要考虑插入一个值使原向量依然保持有序,而如果我们仅仅只是返回一个未查找到的 -1
声明:本文参考 Xuetangx 数据结构 丁俊晖 老师的相关课程,不失为一个个人总结. 首先,这肯定是一个简单而且看起来一目了然的命题.对于有序向量,特别注意是“有序”向量,抓住重要的一个特点,那就是,相同的元素必然是在同一个不间断的区段内的,即相同的元素都是紧邻的构成一个区间. 像这样: 最后要做到: 即重复元素只保留了一个. 考虑到重复元素都是紧邻的,很容易直接写出以下的算法: 也就是,每一元素相同的区间只保留单个元素即可. 由 while 循环和 remove 操作可以得知,算法复杂度为
第二章学习了的R函数: 1 sum 计算和 sum(x,na.rm=TRUE) 计算向量x中所有数的和,其中排除了NA元素 2 median 计算中位数 返回一个样本数据中间的那个数 median(x,na.rm=TRUE) 3 max 计算最大值 max(x,na.rm=TRUE) 4 min 计算最小
插入,不赘述,代码如下: template <typename T> Rank Vector<T>::insert(Rank r,T const& e) { expand(); for (int i = _size; i > r; i--) _elem[i] = elem[i-1];//复制原向量内容 _elem[r] = e; _size++; return r; } 插入前,要使用expand()算法核实是否即将溢出,然后为了保证数组元素物理地址的连续性,将后缀_
本文主要记录<Machine Learning In Action>中第二章的内容.书中以两个具体实例来介绍kNN(k nearest neighbors),分别是: 约会对象预测 手写数字识别 通过“约会对象”功能,基本能够了解到kNN算法的工作原理.“手写数字识别”与“约会对象预测”使用完全一样的算法代码,仅仅是数据集有变化. 约会对象预测 1 约会对象预测功能需求 主人公“张三”喜欢结交新朋友.“系统A”上面注册了很多类似于“张三”的用户,大家都想结交心朋友.“张三”最开始通过自己筛选的
Stealth视频教程学习笔记(第二章) 本文是对Unity官方视频教程Stealth的学习笔记.在此之前,本人整理了Stealth视频的英文字幕,并放到了优酷上.本文将分别对各个视频进行学习总结,提炼出其中的知识点和思路思想. 视频地址在(http://www.youku.com/playlist_show/id_23389553.html),是一个Stealth的专辑,这里只放上本章第一个视频,其它的大家在上面的链接中慢慢看吧. 第二章有一个视频是FLV格式的,我没法把字幕嵌入其中,所以优酷
目标 1. 清除窗口 2.强制完成所有尚未执行的绘图操作 3.在2d或3d空间绘制图元 4.打开.关闭.查询状态 5.控制图元显示 6.在实心物体表面适当位置指定法线向量 7.用顶点数组和缓冲区对象存储和访问几何数据. 8.同时保存和恢复几个状态变量. 1.1 3种基本操作:清除窗口.绘制几何图形.绘制光栅对象. 2. 绘图工具箱: 2.1 清除RGBA模式的窗口 glClearColor(R, G, B, A); //将当前清除颜色设置成为一个状态变量 glClearDepth(1.0); /
第二章 Mablab语言基础 2.1 Matlab的变量与常量 1) input:x=input(‘please enter a numb’) 2) Inf/inf:正无穷大 3) pi:圆周率 4) 默认保留变量:ans 2.2 Matlab的基本数据结构(1) 1) 修改Curent Folder:修改快捷方式的目标属性 2) 向量=数组 3) 行矩阵a=[1 2 3]或a=[1,2,3];列矩阵b=[1 2 3]'或b=[1;2;3] 4) 内置矩阵函数ones(ones(4):4维全1矩