当前位置: 首页 > news >正文

Ruby语言的数据结构

Ruby语言的数据结构详解

Ruby是一种动态、面向对象的编程语言,因其简洁优雅的语法而受到开发者的喜爱。在Ruby中,数据结构是构建和管理数据的一种方式,不同的数据结构适用于不同的场景。本文将详细探讨Ruby中的几种主要数据结构,包括数组、哈希、集合和链表,同时也会讨论它们的特性、使用场景及实例。

一、数组(Array)

数组是Ruby中最基础的数据结构之一,它是一种有序的集合,可以存储一系列元素。Ruby中的数组可以存放不同类型的数据,包括数字、字符串、对象等。数组的索引从0开始,支持动态扩展。

1. 数组的创建与初始化

在Ruby中,可以使用Array类的实例方法来创建数组,也可以使用简洁的字面量表示法。

```ruby

使用字面量创建数组

array1 = [1, 2, 3, 4, 5] array2 = ["apple", "banana", "cherry"]

使用Array.new创建数组

array3 = Array.new(5) # 创建一个包含5个nil的数组 array4 = Array.new(3, 'hello') # 创建一个包含3个'hello'的数组 ```

2. 数组的操作

Ruby中的数组支持大量的操作方法,常用的有:

  • pushpop:向数组末尾添加或移除元素。
  • shiftunshift:从数组开头添加或移除元素。
  • mapselectreject:对数组进行遍历操作,返回新数组。
  • each:遍历数组中的每个元素。

ruby array = [1, 2, 3] array.push(4) # [1, 2, 3, 4] array.pop # 4 array.shift # 1 array.unshift(0) # [0, 2, 3]

3. 数组的切片与拼接

Ruby提供了一些方法来操作数组的部分元素。例如,slice方法和concat方法。

ruby array = [1, 2, 3, 4, 5] sliced = array[1..3] # [2, 3, 4] array.concat([6, 7]) # [1, 2, 3, 4, 5, 6, 7]

4. 数组的排序与查找

数组也提供了一些排序和查找的方法。使用sort可以进行排序,使用include?可以判断某个元素是否存在。

ruby array = [5, 3, 1, 4, 2] sorted_array = array.sort # [1, 2, 3, 4, 5] exists = array.include?(3) # true

二、哈希(Hash)

哈希是一种键值对集合的数据结构,它可以通过键快速访问对应的值。Ruby中的哈希是无序的,键值对的顺序不一定是插入的顺序。

1. 哈希的创建与初始化

哈希可以通过Hash类的实例方法或字面量表示法进行创建。

```ruby

使用字面量创建哈希

hash1 = { "name" => "Alice", "age" => 25 } hash2 = { name: "Bob", age: 30 } # 使用符号作为键

使用Hash.new创建哈希

hash3 = Hash.new { |hash, key| hash[key] = [] } # 默认值为空数组 ```

2. 哈希的操作

哈希提供了丰富的方法来操作键值对:

  • store[]=:添加或更新元素。
  • fetch:获取指定键的值,如果不存在则可以给出默认值。
  • delete:移除指定键的键值对。

ruby hash = { name: "Alice", age: 25 } hash[:gender] = "female" # 添加新的键值对 age = hash.fetch(:age) # 25 hash.delete(:name) # 删除:name键

3. 哈希的迭代与查询

哈希支持类似数组的迭代方法,如eacheach_keyeach_value等。

ruby hash = { a: 1, b: 2, c: 3 } hash.each do |key, value| puts "#{key} => #{value}" end

4. 哈希的合并与比较

两个哈希可以使用merge方法进行合并,使用==进行比较。

ruby hash1 = { a: 1, b: 2 } hash2 = { b: 3, c: 4 } merged_hash = hash1.merge(hash2) # { a: 1, b: 3, c: 4 } is_equal = hash1 == hash2 # false

三、集合(Set)

集合是一种不允许重复元素的数据结构。在Ruby中,集合可以通过Set类来实现。使用集合可以方便地进行数学上的集合操作,如交集、并集等。

1. 集合的创建

要使用集合,首先需要require 'set'。

```ruby require 'set'

set1 = Set.new([1, 2, 3]) set2 = Set.new([2, 3, 4]) ```

2. 集合的操作

集合支持一些基本操作,如添加、删除元素以及集合运算。

ruby set1.add(4) # 添加元素4 set1.delete(2) # 删除元素2 union_set = set1 | set2 # 并集 intersection_set = set1 & set2 # 交集

3. 集合的迭代

集合也支持迭代操作。

ruby set1.each do |element| puts element end

四、链表(LinkedList)

链表是一种更复杂的数据结构,由一系列节点构成,每个节点包含数据和指向下一个节点的指针。在Ruby中,并没有内置的链表类,但我们可以自定义链表。

1. 节点类

首先定义一个节点类。

```ruby class Node attr_accessor :value, :next_node

def initialize(value) @value = value @next_node = nil end end ```

2. 链表类

接着定义链表类。

```ruby class LinkedList attr_accessor :head

def initialize @head = nil end

def append(value) new_node = Node.new(value) if @head.nil? @head = new_node else current = @head current = current.next_node while current.next_node current.next_node = new_node end end

def display current = @head while current puts current.value current = current.next_node end end end ```

3. 链表的操作

通过定义的链表类,可以进行添加、显示等操作。

ruby list = LinkedList.new list.append(1) list.append(2) list.append(3) list.display # 输出1, 2, 3

总结

Ruby是一种功能强大的编程语言,提供了多种数据结构以满足不同的开发需求。数组、哈希和集合是常用的基本数据结构,它们具有各自独特的特点和适用场景;而链表则为复杂的数据操作提供了灵活的解决方案。

通过合理选择数据结构,可以提高代码的可读性和运行效率。在应用程序开发的过程中,深入理解这些数据结构的特性和操作将帮助我们更好地解决问题。在不断学习和应用中,熟悉Ruby的各种数据结构将为我们的编程之旅增添强大的助力。

相关文章:

Ruby语言的数据结构

Ruby语言的数据结构详解 Ruby是一种动态、面向对象的编程语言,因其简洁优雅的语法而受到开发者的喜爱。在Ruby中,数据结构是构建和管理数据的一种方式,不同的数据结构适用于不同的场景。本文将详细探讨Ruby中的几种主要数据结构,…...

Jmeter配置服务代理器 Proxy(二)

1.创建脚本记录器 2.配置:Jmeter代理、端口、记录目标等 3.配置谷歌浏览器代理 浏览器配置代理的详细教程可参考:使用whistle代理-CSDN博客 4.启动Jmeter记录器 点击ok后弹出这个界面,生成了证书: 5.给浏览器安装Jmeter代理的证书…...

Spring Boot 中实现 WebSocket 的方式

在 Spring Boot 中实现 WebSocket 的方式主要有以下几种,每种方式适用于不同的场景和需求: 1. 基于 Spring WebSocket 的实现 特点: 原生支持 WebSocket,基于 Spring 提供的 API。使用 WebSocketConfigurer 和 WebSocketHandler 配置端点和消息处理逻辑。可以通过拦截器访…...

C语言初阶习题【29】杨氏矩阵

1. 题目描述——杨氏矩阵 有一个数字矩阵&#xff0c;矩阵的每行从左到右是递增的&#xff0c;矩阵从上到下是递增的&#xff0c;请编写程序在这样的矩阵中查找某个数字是否存在。 要求&#xff1a;时间复杂度小于O(N); 2. 思路 3. 代码实现1 #include<stdio.h>void fin…...

[操作系统] 深入理解操作系统的概念及定位

概念 任何计算机系统都包含⼀个基本的程序集合&#xff0c;称为操作系统(OS)。 其核心功能如图片所示&#xff0c;包括&#xff1a; 内核 (Kernel)&#xff1a; 内核是操作系统的核心部分&#xff0c;被认为是狭义上的操作系统&#xff0c;直接与硬件打交道。负责进程管理、内…...

Java中对list数据进行手动分页(可直接复用版)

1.获取list列表数据 // 这边用的mybatisplus查询的sql。条件自己组装 List<实体类> result baseMapper.getPageData(lambdaQuery); 2.计算总记录数 // 计算总记录数 int totalRecords result.size(); 3.创建分页对象&#xff0c;并塞入结果值 // 创建分页对象 IPa…...

【HarmonyOS NEXT】鸿蒙跳转华为应用市场目标APP下载页

【HarmonyOS NEXT】鸿蒙跳转华为应用市场目标APP下载页 一、问题背景&#xff1a; 如今&#xff0c;大家都离不开各种手机应用。随着鸿蒙系统用户越来越多&#xff0c;大家都希望能在鸿蒙设备上快速找到想用的 APP。华为应用市场里有海量的 APP&#xff0c;但之前从鸿蒙设备进…...

《研发管理 APQP 软件系统》——汽车电子行业的应用收益分析

全星研发管理 APQP 软件系统在汽车电子行业的应用收益分析 在汽车电子行业&#xff0c;技术革新迅猛&#xff0c;市场竞争激烈。《全星研发管理 APQP 软件系统》的应用&#xff0c;为企业带来了革命性的变化&#xff0c;诸多收益使其成为行业发展的关键驱动力。 《全星研发管理…...

【IDEA 2024】学习笔记--文件选项卡

在我们项目的开发过程中&#xff0c;由于项目涉及的类过多&#xff0c;以至于我们会打开很多的窗口。使用IDEA默认的配置&#xff0c;个人觉得十分不便。 目录 一、设置多个文件选项卡按照文件字母顺序排列 二、设置多个文件选项卡分行显示 一、设置多个文件选项卡按照文件字…...

Android SystemUI——服务启动流程(二)

在 Andorid 系统源码中,package/apps下放的是系统内置的一些 APP,例如 Settings、Camera、Phone、Message 等等。而在 framework/base/package 下,它们也是系统的 APP,SystemUI 就在此目录下。它控制着整个 Android 系统的界面,但其实他也是一个 APP,不同于一般的 APP,它…...

iOS - 内存对齐

1. 基本的内存对齐 // 对象内存对齐 struct objc_object {// isa 指针 8 字节对齐isa_t isa __attribute__((aligned(8))); };// 定义对齐常量 #define WORD_MASK 7UL // 字对齐掩码 #define WORD_SHIFT 3UL // 字对齐位移 #define WORD_SIZE 8 …...

小游戏前端地区获取

目前前端获取除了太平洋&#xff0c;没有其它的了。 //在JS中都是使用的UTF-8&#xff0c;然而requst请求后显示GBK却是乱码&#xff0c;对传入的GBK字符串&#xff0c;要用数据流接收&#xff0c;responseType: "arraybuffer" tt.request({url: "https://whoi…...

AIGC时代:如何快速搞定Spring Boot+Vue全栈开发

文章目录 一、Spring Boot基础二、Vue.js基础三、Spring Boot与Vue.js集成四、性能优化与最佳实践《快速搞定Spring BootVue全栈开发》 内容简介作者简介目录前言/序言本书内容本书特点读者对象 随着人工智能生成内容&#xff08;AIGC&#xff09;技术的迅速发展&#xff0c;…...

MDX语言的多线程编程

MDX语言的多线程编程 引言 多线程编程是一种重要的编程技术&#xff0c;广泛用于提高程序的运行效率和响应速度。随着计算机硬件的发展&#xff0c;多核处理器的普及&#xff0c;多线程编程显得尤为重要。MDX&#xff08;Multi-dimensional Expressions&#xff09;语言作为一…...

Vue.js组件开发-实现输入框与筛选逻辑

在Vue.js组件开发中&#xff0c;实现输入框与筛选逻辑通常涉及创建一个输入框组件&#xff0c;让用户能够输入搜索关键字&#xff0c;并根据这些关键字过滤一个数据列表。 步骤 ‌准备数据‌&#xff1a; 在Vue组件中&#xff0c;准备一个数据列表&#xff08;通常是一个数组…...

配置Allure环境变量【macOS版】

1. 进入github官网&#xff0c;搜索allure 点击进入&#xff0c;下滑找到Download栏目&#xff0c;点击release 2. 下载安装包并解压 我下载的是zip&#xff0c;解压至存放目录&#xff0c;复制该目录。&#xff08;一会配置环境变量用&#xff09; 3. 编辑.zsrch文件&…...

AndroidStudio升级到2024.2.2项目AGP升级8.8.0版本记录

背景 升级as&#xff0c;一般会把agp一起升级。我的原来版本是8.7.2 plugins {id com.android.application version 8.7.2 apply falseid com.android.library version 8.7.2 apply falseid org.jetbrains.kotlin.android version 1.8.10 apply false }升级后版本&#xff1a…...

Require:利用MySQL binlog实现闪回操作

1&#xff0c;闪回原理 【binlog】MySQL binlog以event的形式&#xff0c;记录了MySQL server从启用binlog以来所有的变更信息&#xff0c;能够帮助重现这之间的所有变化。MySQL引入binlog主要有两个目的&#xff1a;一是为了主从复制&#xff1b;二是某些备份还原操作后需要重…...

计算机网络 (40)域名系统DNS

前言 计算机网络域名系统DNS&#xff08;Domain Name System&#xff09;是互联网的基础技术之一&#xff0c;它负责将人类可读的域名转换为计算机用来通信的数字IP地址。 一、基本概念 DNS的主要目的是将域名解析或翻译为IP地址&#xff0c;使得用户可以通过简单易记的域名来访…...

UE5游戏性能优化指南

UE游戏性能和场景优化思路&#xff1a; 1. 可以把可延展性调低&#xff0c;帧率会大幅提高&#xff0c;但画质会大幅降低 2.调整固定灯光&#xff0c;静态光源&#xff0c;烘焙构建光照&#xff0c;灯光重叠距离&#xff0c;关闭阴影 3.设置模型和地形LOD 4.开启Nanite&…...

Gitlab Runner安装与配置

由于格式和图片解析问题&#xff0c;为了更好阅读体验可前往 阅读原文 本篇使用Docker安装Gitlab runner进行runner的安装和注册&#xff0c;其他方式请参考官方文档非Docker安装Gitlab runner 请确保runner版本和gitlab版本兼容以及docker相关版本兼容问题 下载镜像 docker p…...

如何有效防止和解决IP劫持问题

一、什么是IP劫持&#xff1f; IP劫持是一种攻击方式&#xff0c;攻击者通过伪装成合法的IP地址欺骗网络系统&#xff0c;从而非法获取数据或中断服务。这种攻击可以导致数据泄露、服务不可用等多种严重后果。 二、防范措施 启用SSL/TLS加密 SSL/TLS协议可以在客户端和服务器…...

2006-2020年各省人均水资源量数据

2006-2020年各省人均水资源量数据 1、时间&#xff1a;2006-2020年 2、来源&#xff1a;国家统计局、统计年鉴 3、指标&#xff1a;行政区划代码、地区名称、年份、人均水资源量 4、范围&#xff1a;31省 5、指标解释&#xff1a;人均水资源量是指一个国家或地区在一定时期…...

C++基础入门(二)

目录 前言 一、重载 1.函数重载 2.运算符重载 二、构造函数 1.什么是构造函数 2.带参数的构造函数 3.使用初始化列表 4.this关键字 5.new关键字 三、析构函数 1.什么是析构函数 四、静态成员变量 1.静态成员的定义 2.静态成员变量的作用 五、继承 1.继承基本概…...

互联网架构困境:网络与信息安全

当我们说 TCP/IP 没有内置安全属性时&#xff0c;这到底是什么意思&#xff1f;事实上仔细观察身边的世界&#xff0c;很少有内置安全属性的&#xff0c;这源自于石器时代的野人们没有粮仓需要保护。 “互联网前身 ARPAnet 最初来自于美国国防部对等通信需求”&#xff0c;即使…...

HIVE技术

本文章基于黑马免费资料编写。 hive介绍 简介 hive架构 hive需要启动的配置 执行元数据库初始化命令 使用hive必须启动的服务 ./schematool -initSchema -dbType mysql -verbos启动 Hive 创建一个 hive 的日志文件夹 mkdir /export/server/hive/logs启动元数据管理服务 n…...

RustDesk ID更新脚本

RustDesk ID更新脚本 此PowerShell脚本自动更新RustDesk ID和密码&#xff0c;并将信息安全地存储在Bitwarden中。 特点 使用以下选项更新RustDesk ID&#xff1a; 使用系统主机名生成一个随机的9位数输入自定义值 为RustDesk生成新的随机密码将RustDesk ID和密码安全地存储…...

卷积神经网络的底层是傅里叶变换

1 卷积神经网络与傅里叶变换、希尔伯特空间坐标变换的关系_卷积神经网络与傅里页变换之间的关系-CSDN博客 从卷积到图像卷积再到卷积神经网络&#xff0c;到底卷了什么&#xff1f; 一维信号卷积&#xff1a;当前时刻之前的每一个时刻是如何对当前时刻产生影响的 图像卷积&…...

Bootstrap 下拉菜单

Bootstrap 下拉菜单 Bootstrap 是一个流行的前端框架&#xff0c;它提供了许多预构建的组件&#xff0c;其中之一就是下拉菜单。下拉菜单是一个交互式元素&#xff0c;允许用户从一系列选项中选择一个。在本篇文章中&#xff0c;我们将详细介绍如何在 Bootstrap 中创建和使用下…...

计算机组成原理(计算机系统3)--实验一:WinMIPS64模拟器实验

一、实验目标&#xff1a; 了解WinMIPS64的基本功能和作用&#xff1b; 熟悉MIPS指令、初步建立指令流水执行的感性认识&#xff1b; 掌握该工具的基本命令和操作&#xff0c;为流水线实验做准备。 二、实验内容 按照下面的实验步骤及说明&#xff0c;完成相关操作记录实验…...

有什么网站可以做投票功能吗/国际国内新闻最新消息今天

(?iLmsux)iLmsux每个字符代表一个匹配模式(?!abc)Abc, abc, ......(?#...)#之后的内容作为注释被忽略 (?...)之后的字符串内容需要匹配表达式&#xff0c;不消耗字符串内容a(?d)后面是数字的a (?!...)之后的字符串内容需要不匹配表达式&#xff0c;不消耗字符串内容a(?!…...

南京网站开发公司/优化网站标题是什么意思

浏览器不出现滚动条&#xff1a; ::webkit-scrollbar{display:none; } css样式中的所属关系表达式&#xff1a; .content{} //点表示类&#xff0c;后面content表示类名 .content div{} //类content下的 div标签 .content div>ul{} //类content下的div标签下的…...

网站评估内容 优帮云/小网站关键词搜什么

在standalone.xml中&#xff1a; 找到下面三行&#xff0c;看到是要访问public&#xff08;8080端口的&#xff09;和management的interface&#xff0c;将interface中的127.0.0.1改为0.0.0.0即可。 <socket-binding-group name"standard-sockets" default-interf…...

网站建站作业/网盘搜索

转载&#xff1a;https://blog.csdn.net/yiyihuazi/article/details/82937399 膜拜大佬&#xff0c;感谢大佬&#xff01;&#xff01;&#xff01;...

怎么把自己做的网站发布/军事网站大全军事网

首先声明&#xff1a;我们要构建的是扩展或者模块名为hello_module.该模块提供一个方法&#xff1a;hello_word. 一、PHP环境的搭建 1&#xff09;一般使用源码包编译安装&#xff0c;而不是binary包安装。因为使用PHP的二进制分发包安装有些冒险&#xff0c;这些版本倾向于忽略…...

wordpress手机中文版/想学编程去哪里找培训班

Java使用Thread类代表线程&#xff0c;所有线程都是Thread类或其子类&#xff0c;Java创建线程的方式有4种&#xff0c;它们分别是&#xff1a;1、继承Thread类创建线程&#xff1b;2、实现Runable接口创建线程(首推)&#xff1b;3、使用Callable和Future创建线程&#xff1b;4…...