快速查询List中指定的数据
| (1,1) (xIndex,yIndex) | (2,1) | (3,1) | (。。。,。。。) |
| (1,2) | (2,2) | (3,2) | (。。。,。。。) |
| (1,3) | (2,3) | (3,3) | (。。。,。。。) |
| (。。。,。。。) | (。。。,。。。) | (。。。,。。。) | (10000,50) |



.png)
//传统遍历
var objPoints = from b in listPoints where b.xIndex == Convert.ToInt32(this.tbX.Text.Trim().ToString()) select b;
foreach (var item in objPoints)
{
showPoints(item); //显示当前点的text属性值;
}
hsTemp.Clear();//清空哈希表
int TempCount = listPoints.Count;
; i < TempCount; i++)
{
if (hsTemp.ContainsKey(listPoints[i].xIndex.ToString()))//如果哈希表中存在key值
{
hsTemp[listPoints[i].xIndex.ToString()] += "," + i.ToString();//这里和数组结构类似,改变索引值对应的value值信息
}
else
{
hsTemp.Add(listPoints[i].xIndex.ToString(), i);
}
}
this.richTextBox1.Text = "新方法查询结果:\n";
//objPonit = new MyPoint();
string currentPX = this.tbX.Text.Trim().ToString();
if (listPoints != null && currentPX != null)
{
int TempCount = listPoints.Count;
&& hsTemp.Count <= )//如果list中有数据而哈希表中却没有数据
{
FlushTempIndex();
}
if (hsTemp.ContainsKey(currentPX))
{
string[] arrTempIndex = hsTemp[currentPX].ToString().Split(',');//可以直接将分好的数据放到数组中去
int TempIndexCount = arrTempIndex.Length;
;
; i < TempIndexCount; i++)
{
if (int.TryParse(arrTempIndex[i], out TempIndex) && TempIndex < TempCount)
{
showPoints(listPoints[TempIndex]);
}
}
}
}
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
namespace 快速查询数据.Models
{
public class MyPoint
{
public int xIndex { get; set; }
public int yIndex { get; set; }
public string text { get; set; }
}
}
using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using 快速查询数据.Models;
using System.Collections;
namespace 快速查询数据
{
public partial class Form1 : Form
{
List<MyPoint> listPoints = new List<MyPoint>();
private Hashtable hsTemp = new Hashtable();
MyPoint objPonit = null;
public Form1()
{
InitializeComponent();
this.tbY.Enabled = false;
generaPoints();
}
//生成数据源
private void generaPoints()
{
;
; i <= ; i++)
{
; j <= ; j++)
{
objPonit = new MyPoint() { xIndex=i,yIndex=j,text=""+count};
count++;
listPoints.Add(objPonit);
}
}
}
//执行查询
private void btQuery_Click(object sender, EventArgs e)
{
this.richTextBox1.Text = null;
DateTime beforDT = System.DateTime.Now;
//耗时巨大的代码
method2();
DateTime afterDT = System.DateTime.Now;
TimeSpan ts = afterDT.Subtract(beforDT);
this.textBox1.Text = ts.TotalMilliseconds.ToString()+" ms";
}
//显示
private void showPoints(MyPoint objMyPoint)
{
this.richTextBox1.Text += "," + objMyPoint.text;
}
/// <summary>
/// LinQ查询
/// </summary>
private void method1()
{
this.richTextBox1.Text = "传统方法查询结果:\n";
var objPoints = from b in listPoints where b.xIndex == Convert.ToInt32(this.tbX.Text.Trim().ToString()) select b;
foreach (var item in objPoints)
{
showPoints(item);
}
}
/// <summary>
/// List和Hashtable集合查询
/// </summary>
private void method2()
{
this.richTextBox1.Text = "新方法查询结果:\n";
//objPonit = new MyPoint();
string currentPX = this.tbX.Text.Trim().ToString();
if (listPoints != null && currentPX != null)
{
int TempCount = listPoints.Count;
&& hsTemp.Count <= )//如果list中有数据而哈希表中却没有数据
{
FlushTempIndex();
}
if (hsTemp.ContainsKey(currentPX))
{
string[] arrTempIndex = hsTemp[currentPX].ToString().Split(',');//可以直接将分好的数据放到数组中去
int TempIndexCount = arrTempIndex.Length;
;
; i < TempIndexCount; i++)
{
if (int.TryParse(arrTempIndex[i], out TempIndex) && TempIndex < TempCount)
{
showPoints(listPoints[TempIndex]);
}
}
}
}
}
public void FlushTempIndex()
{
hsTemp.Clear();//清空哈希表
int TempCount = listPoints.Count;
; i < TempCount; i++)
{
if (hsTemp.ContainsKey(listPoints[i].xIndex.ToString()))//如果哈希表中存在key值
{
hsTemp[listPoints[i].xIndex.ToString()] += "," + i.ToString();//这里和数组结构类似,改变索引值对应的value值信息
}
else
{
hsTemp.Add(listPoints[i].xIndex.ToString(), i);
}
}
}
}
}
快速查询List中指定的数据的更多相关文章
- mssql sqlserver 禁止删除数据表中指定行数据(转自:http://www.maomao365.com/?p=5323)
转自:http://www.maomao365.com/?p=5323 摘要:下文主要讲述,如何禁止删除数据表中指定行数据 最近收到用户一个需求,禁止所有人删除”表A”中,ID 为1.2.3.4.5的 ...
- 每日学习心得:SharePoint 为列表中的文件夹添加子项(文件夹)、新增指定内容类型的子项、查询列表中指定的文件夹下的内容
前言: 这里主要是针对列表中的文件下新增子项的操作,同时在新建子项时,可以为子项指定特定的内容类型,在某些时候需要查询指定的文件夹下的内容,针对这些场景都一一给力示例和说明,都是一些很小的知识点,希望 ...
- SQL查询显示行号、随机查询、取指定行数据
转自:walkingp 1.显示行号 如果数据没有删除的情况下主键与行号是一致的,但在删除某些数据,行号就与主键不一致了,这时需要查询行号就需要用新的方法,在SQL Server2005之前,需要使用 ...
- 快速向表中插入大量数据Oracle中append与Nologging
来源于:http://blog.sina.com.cn/s/blog_61cd89f60102e7gi.html 当需要对一个非常大的表INSERT的时候,会消耗非常多的资源,因为update表的时候 ...
- 用Spark查询HBase中的表数据
java代码如下: package db.query; import org.apache.commons.logging.Log; import org.apache.commons.logging ...
- 【Linux】查询文件中指定字符串的记录
语法 cat 文件 |grep 查询字符串 例如现在有文件file.dat,文件中内容如下: zhangsan Lisi wangwu123 wangwu890 zhangsan28290 现在想从文 ...
- Mysql快速删除表中重复的数据
表结构 CREATE TABLE T_VENDOR ( ID ) NOT NULL AUTO_INCREMENT COMMENT 'ID', COUNTRY ) DEFAULT NULL COMMEN ...
- 超实用--删除MYSQL中指定的数据的全部表
作过的人都知道,重复测试数据库的苦恼. 用法:# Usage: ./script user password dbnane mysql.nixcraft.in ~~~~~~~~~~~~~ #!/bin ...
- Java快速向数据库中插入大量数据 比如10万条以上
String sql = "insert into table *****"; //必须要有这句,要不然效果不明显 con.setAutoCommit(false); ps = c ...
随机推荐
- 在服务器上用Fiddler抓取HTTPS流量
转自:http://yoursunny.com/t/2011/FiddlerHTTPS/在服务器上用Fiddler抓取HTTPS流量 阳光男孩 发表于2011-03-19 开发互联网应用的过程中,常常 ...
- Chart.js – 效果精美的 HTML5 Canvas 图表库
Chart.js 是一个令人印象深刻的 JavaScript 图表库,建立在 HTML5 Canvas 基础上.目前,它支持6种图表类型(折线图,条形图,雷达图,饼图,柱状图和极地区域区).而且,这是 ...
- Asynchronous and Distributed Programming in R with the Future Package
Every now and again someone comes along and writes an R package that I consider to be a 'game change ...
- vuex所有核心概念完整解析State Getters Mutations Actions
vuex是解决vue组件和组件件相互通信而存在的,vue理解起来稍微复杂但一旦看懂择即为好用 安装: npm install --save vuex 引入 import Vuex from 'vuex ...
- MPP 二、Greenplum数据加载
Loading external data into greenplum database table using different ways... Greenplum 有常规的COPY加载方法,有 ...
- 数据库MySQL纯净卸载
有些人在安装MySQL后,卸载后再次安装时,一直安装不上去,到最后不得不重装系统来安装MySQL.这里教大家如何将MySQL卸载干净,不影响下次安装. 卸载过程 1.停止mysql服务 2.进行卸载 ...
- MarkDown编辑器快捷方式
常用快捷: Ctrl+K 插入代码块 Ctrl+G 插入图片 Ctrl+B 文字加粗 Ctrl+I 文字倾斜 Ctrl+G 插入图片 Tab 默认新建高亮代码块 ">" 向右 ...
- Java常用类之【Math类、Random类、System类、Runtime类】
一.Math类 Math类 [绝对值]Math.abs();//返回对应类型的绝对值 [最大值和最小值]Math.max(int a, int b) ,Math.min(int a,int b);(其 ...
- [原创]adb使用教程v1.0-----by-----使用logcat快速抓取android崩溃日志
原文再续,书接上回:<使用logcat快速抓取android崩溃日志>中提到的工具包可以下载拉~ <使用logcat快速抓取android崩溃日志>:http://www.cn ...
- Python3实现简单的http server
前端的开发的html给我们的时候,由于内部有一些ajax请求的.json的数据,需要在一个web server中查看,每次放到http服务器太麻烦.还是直接用python造一个最方便. 最简单的,直接 ...