C# 在锯齿状数组中快速查找值的方法

2024-03-16

我有一个锯齿状数组String[][]。现在我需要找到具有特定值的数组String[n][0]我现在所拥有的只是一个简单的

foreach foo in bar{
 if(foo[0]==needle){
  return foo;
 }
}

正如您所看到的,由于显而易见的原因,这非常慢。我是 C# 新手,刚刚看到了 indexOf,但是如何在锯齿状数组中使用 indexOf 呢?

我想到的另一种方法是对数组进行排序String[n][0],转到中间的记录,检查我的值是否更大或更大,跳到上/下区域的一半等等,也许3或4次,这样我可以更快地找到记录。

那么,在我只知道的锯齿状数组中获取数组的最快方法是什么[][0]?


我会用一个Dictionary<int, int[]>其中键是数组的第一项。字典具有恒定的时间访问,并且如果整个数据适合内存,则随机访问速度非常快。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

C# 在锯齿状数组中快速查找值的方法 的相关文章

  • 如何使用 Qtimer 添加 1 秒延迟

    我目前有一个方法如下 void SomeMethod int a Delay for one sec timer gt start 1000 After one sec SomeOtherFunction a 这个方法实际上是一个附加到信号
  • 使用 getopt_long (C++) 如何为两个需要参数编写长选项和短选项?

    include
  • 如何查找boost运行时版本

    我正在编写一个使用 boost 的 C 库 在这个库中 我想包含有关用于编译我的库的二进制版本的 boost 版本的信息 我可以使用宏BOOST VERSION这很好 我还想确定哪个是 boost 的运行时版本 以便我可以与用于编译我的库的
  • 实体框架 - 循环更新属性

    我正在尝试找到一种方法来循环 EF 对象的属性并更新这些属性的值 更具体地说 我有 50 个字段 其中最多填充 50 个下拉列表 所有 50 个可能都需要填充 也可能不需要填充 为了解决这个问题 我有一个中继器 最多可以创建 50 个 DD
  • 如何将 pem 公钥转换为 openssl RSA* 结构

    假设我必须像这样公开 pem 密钥 BEGIN PUBLIC KEY MIGfMA0GCSqGSIb3DQEBAQUAA4GNADCBiQKBgQC7vbqajDw4o6gJy8UtmIbkcpnk O3Kwc4qsEnSZp TR fQi
  • WPF MVVM将DataTable绑定到DataGrid不显示数据

    我有一个简单的控件 其中包含一个 DataGrid 其中 ItemsSource 绑定到 DataTable 当我填充 DataTable 时 我可以看到 DataGrid 中添加了行 但没有显示任何数据 我没有为此 DataGrid 使用
  • 使用 C 创建立体声正弦波

    我正在尝试用 C 创建立体声正弦 WAV 并且可能有不同的 可能是空白的 左声道和右声道 使用此函数为每个通道生成一个音调 int16 t create tone float frequency float amplitude float
  • C++ 克隆惯用语中协变返回类型的用处?

    通常的克隆习惯使用协变返回类型 struct Base virtual Base clone struct Derived public Base Derived clone 我读过一些内容 大意是协变返回类型是 C 后来添加的 较旧的编译
  • 让 WIX 在项目中包含引用

    我对 WiX 和设置自定义安装程序完全陌生 所以我对问题的主题表示歉意 我有一个内部业务应用程序 日记 它构建并运行良好 因此我按照教程 官方文档添加 WiX 项目并引用日记的 csproj 然后构建并运行这个最基本版本的 WiX 安装程序
  • Emacs 行编号性能

    我试过了linum and nlinum 两者对于超过 100k 行的文件的性能都很糟糕 for x in 1 100000 do echo x done gt 100k txt emacs q 100k txt M x load libr
  • 如何使用 Caliburn.Micro MVVM 将焦点设置到控件

    我有一个表单 我想在发生某些用户操作时将焦点设置到文本框 我知道 MVVM 的处理方式是绑定到 VM 属性 但是 TextBox 没有允许这种情况发生的属性 从虚拟机设置焦点的最佳方法是什么 我创建了一个 IResult 实现 可以很好地实
  • 允许 .NET WebApi 忽略 DOCTYPE 声明

    我正在尝试通过 WebApi 方法将 XML 反序列化为对象 我有以下课程 XmlRoot IsNullable false public class MyObject XmlElement Name public string Name
  • 如何在 Xamarin.Mac 中执行终端命令并读入其输出

    我们正在编写一个 Xamarin Mac 应用程序 我们需要执行像 uptime 这样的命令 并将其输出读取到应用程序中进行解析 这可以做到吗 在 Swift 和 Objective C 中都有 NTask 但我似乎无法在 C 中找到任何示
  • 修改公共属性的访问修饰符是否是重大更改?

    如果我将公共属性的 setter 的访问修饰符从私有更改为公共 是否会导致引用它的其他程序集发生任何重大更改 UPDATE 这个问题是我 2012 年 1 月博客的主题 https ericlippert com 2012 01 09 ev
  • 在同一条线上铸造两次

    我在项目中看到了这段代码 b的类型是void void b int a int unsigned long b 这条线毫无意义吗 我的意思是 这与a int b在所有情况下 这可能会避免 64 位 Unix 系统上的编译器警告unsigne
  • #define, #ifdef #undef #endif

    我有以下代码 define PROC ADD void main void while 1 ifdef PROC ADD Do this code here then undefined it to run the code in the
  • Yield Return == IEnumerable 和 IEnumerator 吗?

    Is yield return实施的捷径IEnumerable and IEnumerator 是的 您可以在我的书 C in Depth 的第 6 章中找到更多相关信息 幸好第六章是免费提供 http www manning source
  • 更新插入 MongoDB 时如何防止出现“_t”字段?

    我有一个应用程序 它使用 MongoDB 的 C 驱动程序将 Upsert 插入 MongoDB 数据库 当我打电话给Update函数 我无法指定我要更新的类型 然后 t字段插入元素的类型 这是我用来更新插入的代码 collection U
  • 如果未返回,则在一段时间后终止线程

    我有一个线程从网络或串行端口获取一些数据 如果 5 秒内没有收到数据 则线程必须终止 或返回 false 换句话说 如果线程运行时间超过 5 秒 则必须停止 我用 C 编写 但任何 NET 语言都可以 有两种方法 1 封装超时 从网络或串行
  • 如何在Asp.Net Core中自定义开发者异常页面?

    这常见于ConfigureStartup cs 文件的方法具有如下所示的代码 if env IsDevelopment app UseDeveloperExceptionPage new DeveloperExceptionPageOpti

随机推荐

  • 如何将 2 个数据帧直方图合并到 1 个图中?

    我想使用显示数据框中所有直方图的代码 那将是df hist bins 10 但是 我想添加另一个显示 CDF 的直方图df hist df hist cumulative True bins 100 density 1 histtype s
  • 如何在 Angular 中包含本地库?

    当我创建一个Angular我想构建一个库 我可以在其中放置甚至在其他项目中也有用的组件 为了创建这个库 我做了另一个Angular我在其中生成了库项目并使用工作区中自动生成的应用程序项目来显示各个组件 ng new my component
  • 使用 netbeans 将 ArrayList 加载到 JCombobox 中

    目前有一个名为 ArrayList周日列表一旦框架加载添加学生已加载 GUI 的位 Netbeans自动生成的代码是 comboboxSunday new javax swing JComboBox comboboxSunday setMo
  • 如何在 firebase android 的 recyclerview / cardlayout 中显示最新帖子在顶部而不是底部?

    我对 Java 和 Firebase 完全陌生 正在从事一个大学项目 制作类似电子商务应用程序的东西 但不是字面上的 有点相似 到目前为止 我新插入的数据默认位于底部 我需要将它们放在顶部 在 stackoverflow 上尝试了所有可能的
  • HTML 音频元素第一次无法播放?

    我正在使用 htmlaudio我的一个项目中的一个元素 一旦按下播放按钮 我就会使用 VueJS 动态加载该元素的 src 一切似乎都工作正常 但是当我第一次按下按钮时 音频无法播放 我必须再次单击播放按钮才能开始播放 我怎样才能解决这个问
  • 如何使用 LayoutInflater / ViewStub 进行覆盖

    由于我实际上对以编程方式更改视图不太有信心 因此我遇到以下问题 在我的应用程序第一次启动时 我希望主屏幕有一个覆盖层 告诉用户查看设置 因为用户必须配置两个关键选项 我不想使用AlertDialog而不是使用向导 因此 我决定采用类似于 G
  • 添加外键错误

    我想从表中添加外键Customers row Customer ID 到餐桌宠物 row Customer ID Table structure for table Customers CREATE TABLE IF NOT EXISTS
  • 2D 变换过渡不适用于 IE11 中的 VW 和 VH 单位

    当我尝试使用过渡来为变换 TranslateY 制作动画时 我在 IE11 和 10 上遇到了一个奇怪的问题 我有一个天空盒 里面有一个天空 高度为 500vh 该天空必须根据视口中的当前部分上下移动 视口是一个绝对 位置元素 用于处理内容
  • Spring + Hibernate save() 不工作

    我在下面附上 Spring 服务 有问题 代码 Async public void performSeismicOperations Integer sessionUserId int seismicFileId String seismi
  • 在 Rails 6 中省略 bin/rails 路由中的操作邮箱、activestorage 和conductor 路由?

    我有一个全新的 Rails 6 应用程序 但没有anything in the config routes rb 输出bin rails routes有大量 ActiveStorage Action Mailbox 和 Conductor
  • 如何控制 .Net 在命名空间冲突中选择哪个程序集?

    由于某种原因 我需要 请耐心等待 使用 System Text Encoding 命名空间的 WinRT 版本 我可以手动添加对程序集的引用等 但它仍然会使用 mscorlib 的实现 而且我显然无法完全删除 mscorlib 如何强制我的
  • stargazer type = "html" 表输出中列之间的空格

    我正在寻找一种方法 或替代方案 来获取 stargazer html table 输出的列之间的空格 As stargazer stargazer mtcars type html 结果是 这不太好读 提前致谢 Samuel 您还可以将 C
  • 在 shell 中重命名多个文件[重复]

    这个问题在这里已经有答案了 我在一个目录中有多个文件 例如 linux file1 mp4 linux file2 mp4等等 如何使用 shell 移动这些文件 以便名称为file1 mp4 file2 mp4等等 我有大约 30 个文件
  • 显示来自 Rails 应用程序的 Twitter feed

    我已经能够让用户通过 OmniAuth 登录 Twitter 我遵循 Railscast 235 6 并制作了一个简单的应用程序 现在我正在尝试显示已登录用户的 Twitter 提要 谁能告诉我这是怎么做到的 如何初始化 Twitter 如
  • Git http.proxy 设置

    我试图弄清楚这个 git 问题 有一次我搞乱了 http proxy 变量 现在这只是废话 asdf 所以推动不起作用 我不知道之前的代理设置是什么 我什至不知道代理服务器是什么 有什么方法可以将 http proxy 设置为正确的值吗 现
  • 将 Zookeeper 从 3.3.X 升级到 3.4.X 时,我需要了解哪些信息?

    我有一个 Zookeeper 整体 我想从 3 3 X 分支升级到 3 4 X 分支 这可以在实时集群上完成吗 需要停机吗 有什么说明可以在某处找到吗 据我检查 升级 ZooKeeper 有哪些选项 流程 有两种主要方法可以做到这一点 1
  • 数据报总是被完整接收吗?

    大多数数据报接收函数 例如c的recv或read java的DatagramPacket类或python的SocketServer 都包含找出接收数据量的可能性 c int amount recv sock buf n MSG WAITAL
  • ASP.NET Web API - OWIN - TokenEndPointPath 在 IIS 中不起作用

    我的startup cs 中有以下代码 当 Web API 项目部署到 IIS 中网站的根目录时 在 IIS Express 中设置 TokenEndpointPath 效果非常好 但是 如果我托管在 IIS 中的嵌套应用程序 即网站内的应
  • 使用php从linux访问windows共享文件夹

    我需要能够使用在 Linux 服务器上运行的 php 脚本访问多个 Windows 服务器上的一些共享文件夹 我只需要获取文件夹中包含的文件的名称以及创建它们的时间戳 到目前为止 我想到的唯一解决方案是在 Linux 中安装共享并从那里访问
  • C# 在锯齿状数组中快速查找值的方法

    我有一个锯齿状数组String 现在我需要找到具有特定值的数组String n 0 我现在所拥有的只是一个简单的 foreach foo in bar if foo 0 needle return foo 正如您所看到的 由于显而易见的原因