Ruby Array类
| 生成 |
a = [1,2,3] # 字面生成 |
||||||||||||
| 复制 |
clone -> Array dup -> Array ● 元素不复制(指针的还是指针) ● clone也包含了frozen tainted singleton-class的内容 |
||||||||||||
| 索引 | a = Array.new(12, 1) 获取一个 b = a[1] b = a.at(1) b = a.slice(1) 获取子数组 b = a[1..2] b = a.slice(1..2) b = a[1...2] b = a.slice(1...2) 获取子数组, 通过首项和数组长度 b = a[1, 5] b = a.slice(1..6) |
||||||||||||
| 插入新元素 | b = Array.new(4, 95) a[n, 0] = b |
||||||||||||
| 取出多个元素 | a.values_at(n1, n2, ...) | ||||||||||||
| 长度 | a.length a.size |
||||||||||||
| 是否包含指定元素 | include?(val) -> bool | ||||||||||||
| 集合运算 | 并集 a | b 交集 a & b | 和 +的区别 |
||||||||||||
| 序列和堆 | 序列: 先放的先拿 堆: 先放的后拿 |
||||||||||||
| 增加元素 |
|
||||||||||||
| 删除元素 |
|
||||||||||||
| 读取元素 |
开头: first(n) 结尾: last(n) 第二个: second() 这个不能有参数 开头开始指定个: take(n) |
||||||||||||
|
搜索元素 |
|
||||||||||||
| 主要方法 | 注:改变自己的method会改变所以参照的对象 | ||||||||||||
| 增加首元素 | a.unshift(n) | ||||||||||||
| 增加尾元素 | a.push(n) a << n | ||||||||||||
| 末尾添加数组 | a.concat(b) a += b | ||||||||||||
| 取出一部分 | a[n], a[m...n], a[m..n], a[n, length]
a[n] 取出第n个 |
||||||||||||
| 删除nil | a.compact() 去除nil | ||||||||||||
| 去掉所有n | a.delete(n) 去除所有n |
||||||||||||
| 删掉第n+1个 | a.delete_at(n) 去除第n+1个 | ||||||||||||
| 满足条件时删除 |
删除返回true的 a.delete_if do |temp| # 总是返回自身 相当于 a.reject! do |temp| |
||||||||||||
| 去除重复 | a.uniq() a.uniq!() |
||||||||||||
| 读取并删除首元素 读取并删除尾元素 |
a.shift() a.pop() |
||||||||||||
| 加工原数组 |
a.collect {|temp| 注: map, collect是同一个方法 返回值作为新元素, 不返回则为nil |
||||||||||||
| 填充新值 | a.fill(value) a.fill(value, begin) a.fill(value, begin, len) a.fill(value, n..m) |
||||||||||||
| 展开所有子集合 | a.flatten() a.flatten!() |
||||||||||||
| 倒转 | a.reverse() a.reverse!() |
||||||||||||
| 排序 | a.sort() a.sort!() a.sort {|temp| ...} a.sort! {|temp| ...} sampe = target.sort { |a, b| b.contents.count <=> a.contents.count } |
||||||||||||
| 通过某个值排序 | a.sort_by {|temp| ...} a.sort_by! {|temp| ...} 注意: 从小到大排(升序) |
||||||||||||
| 遍历 | a.each {|temp|} a.zip 带索引 从0开始 a.each_with_index {|temp, index|} 从n开始 a.each.with_index(n) {|temp, index|} |
||||||||||||
| 获取字符串 |
a.join(sep="") 按将数组内容按sep为分割连结成字符串 [1, 2, 3].join('/') # '1/2/3' |
||||||||||||
Ruby Array类的更多相关文章
- Java集合---Array类源码解析
Java集合---Array类源码解析 ---转自:牛奶.不加糖 一.Arrays.sort()数组排序 Java Arrays中提供了对所有类型的排序.其中主要分为Prim ...
- .NET中string[]数组和List<string>泛型的相互转换以及Array类的Sort()方法(转)
从string[]转List<string>: " }; List<string> list = new List<string>(str); 从List ...
- javascript Array类
Array类 toString()方法和valueOf()方法,返回特殊的字符串.该字符串是通过对每项调用toString()方法,然后用逗号把它们连接在一起构成的.例如,对具有项"red& ...
- C# - 系统类 - Array类
Array类 ns:System Array是一个抽象类 表示数组 提供了创建.查找.删除.排序.修改等应用于数组的操作 此类没有公有的实例构造函数 可以使用静态方法CreateInstance创建A ...
- Array类的Sort()方法
刚复习了Array类的sort()方法, 这里列举几个常用的,和大家一起分享. Array类实现了数组中元素的冒泡排序.Sort()方法要求数组中的元素实现IComparable接口.如System. ...
- C#数组--(Array类的属性和方法)
Array 类是 C# 中所有数组的基类,它是在 System 命名空间中定义.Array 类提供了各种用于数组的属性和方法,可看作扩充了功能的数组(但不等同数组),可以使用Array类的属性来对数组 ...
- C#编程(三十三)----------Array类
Array类 创建数组 Array intArray1 = Array.CreateInstance(typeof(int), 5); for (int i = 0; i < 5; i++) { ...
- C#中的集合(HashTable与Array类)【转】
一.Array类 1.Array类的属性 序号 属性 & 描述 1 IsFixedSize 获取一个值,该值指示数组是否带有固定大小. 2 IsReadOnly 获取一个值,该值指示数组是否只 ...
- Eigen学习之Array类
Eigen 不仅提供了Matrix和Vector结构,还提供了Array结构.区别如下,Matrix和Vector就是线性代数中定义的矩阵和向量,所有的数学运算都和数学上一致.但是存在一个问题是数学上 ...
随机推荐
- 解决Flex4在Module里调用PopUpManager报错问题
项目大了 就需要用到Module, 发现在一个Module里边, 和普通应用里一样popup一个组件的时候, 总是会报错. 这个在Flex3的时候也会出现, 会报样式错误 所以就想到了addPopUp ...
- 动态规划:HDU 1114 Piggy-Bank
Problem Description Before ACM can do anything, a budget must be prepared and the necessary financia ...
- Construct Binary Tree from Preorder and Inorder Traversal (DFS,参考)
Given preorder and inorder traversal of a tree, construct the binary tree. Note:You may assume that ...
- 分享一下然让显卡满血复活的小技巧(GTX)
分享一下然让显卡满血复活的小技巧 笔者在玩大型游戏卡顿15fps下载如下操作 GTX950玩大型游戏都不会卡帧率稳定在30fps 下载GeForce Experience下载更新最新驱动 下载如下程序 ...
- 【网络】TCP的拥塞控制
一.拥塞控制的一般原理 拥塞:对网络中某一资源的需求超过了该资源所能提供的可用部分 拥塞控制是防止过多的数据注入到网络,这样可以使网络中的路由器或链路不致过载,拥塞控制是一个全局性的过程. 流量控制往 ...
- HNU 12834 Thread Tree
递归输出即可了 #include<bits/stdc++.h> using namespace std; struct tree{ int dot; string s; } ...
- DacningLinks实现
本文简单分析DancingLinks实现中的数据结构设计,给出了精确覆盖问题及其扩展问题的代码.并应用于数独问题. 先简单描写叙述一下精确覆盖问题: 给定一个N*M的01矩阵,从中选中若干行,这些行向 ...
- [CSAPP]Bufbomb实验报告
Bufbomb实验报告 实验分析: level 0-3从test開始制运行,通过函数getbuf向外界读取一串内容(buf). Level 4 是通过參数-n,程序运行testn函数,调用getbuf ...
- Qt实现一个简单的TextEditor
使用QT实现简单的TextEditor: 首先在窗口添加部件TextEditor,并设置中文字符 MainWindow::MainWindow(QWidget *parent) : QMainWind ...
- CRF图像切割简单介绍
这里主要是讲Conditional Random Fields(CRF)用于pixel-wise的图像标记(事实上就是图像切割).CRF经经常使用于 pixel-wise的label 预測.当把像素的 ...