C#位图算法

在处理表格合并等问题时,可以考虑采用位图算法实现二维存储对象的处理

通过Map.Set设置点值或Map.Fill填充区域。
判断各点值时通过Map.Get获取

扩展Point属性可以改成3维或更多维实现多维存储对象的处理

/// <summary>
/// 二维图形算法
/// 王洪岐 121226
/// </summary>
/// <typeparam name="T"></typeparam>
public class Map<T>
{
private Dictionary<Point, T> _map;
/// <summary>
/// 构建图
/// </summary>
/// <param name="x"></param>
/// <param name="y"></param>
public Map()
{
_map = new Dictionary<Point, T>();
}
/// <summary>
/// 填充图
/// </summary>
/// <param name="a"></param>
/// <param name="b"></param>
public void Fill(Point a, Point b, T value)
{
for (int x = Math.Min(a.X, b.X); x <= Math.Max(a.X, b.X); x++)
{
for (int y = Math.Min(a.Y, b.Y); y <= Math.Max(a.Y, b.Y); y++)
{
_map[new Point(x, y)] = value;
}
}
}
/// <summary>
/// 设置单点值
/// </summary>
/// <param name="a"></param>
/// <param name="value"></param>
public void Set(Point p, T value)
{
_map[p] = value;
}
/// <summary>
/// 获取单点值
/// </summary>
/// <param name="p"></param>
/// <returns></returns>
public T Get(Point p)
{
return _map.ContainsKey(p) ? _map[p] : default(T);
}
/// <summary>
/// 显示点
/// </summary>
/// <returns></returns>
public string ShowPoint()
{
int intMaxX= _map.Keys.Max(p=>p.X);
int intMaxY= _map.Keys.Max(p=>p.Y);
StringBuilder sbReturn = new StringBuilder();
for (int y = 0; y <= intMaxY; y++)
{
for (int x = 0; x <= intMaxX; x++)
{
sbReturn.Append(_map.ContainsKey(new Point(x, y))?"1":"0");
}
sbReturn.Append("\n");
}
return sbReturn.ToString();
}
}
/// <summary>
/// 点坐标
/// </summary>
public struct Point
{
private int _X;
private int _Y;
/// <summary>
/// 
/// </summary>
/// <param name="x"></param>
/// <param name="y"></param>
public Point(int x, int y)
{
_X = x;
_Y = y;
}
/// <summary>
/// X
/// </summary>
public int X
{
get
{
return _X;
}
set
{
_X = value;
}
}
/// <summary>
/// Y
/// </summary>
public int Y
{
get
{
return _Y;
}
set
{
_Y = value;
}
}
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/417168.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

从零开始学JavaWeb

引言 记得上学时,有位导师说过一句很经典的话:"编程语言只是工具,最重要的是掌握思想。" 笔者一直主要从事.net领域的开发工作。随着工作阅历的丰富&#xff0c;越来越深刻的理解当年导师说的那句话的意义。 "他山之石,可以攻玉",相互借鉴,然后为我所用,无…

嵌入式linux截屏代码,嵌入式linux截屏程序

基于网上一个代码改的。源地址&#xff1a;http://blog.csdn.net/z1179675084/article/details/14645359// 注意&#xff0c;由于fb_bpp 16的情况没用到&#xff0c;以下修改后的代码只调整了fb_bpp不为16的情况#include #include #include #include #include #include #inclu…

MongoDB分布式(分片存储)部署

分别开启一个Config和两个ShardD:\mongodb1\bin\mongod --configsvr --dbpath D:\mongodb1\db\ --port 27020D:\mongodb2\bin\mongod --dbpath D:\mongodb2\db\ --port 27021D:\mongodb3\bin\mongod --dbpath D:\mongodb3\db\ --port 27022启动mongos(Sharding controller分片控…

(转)找回vss超级管理员密码

原文&#xff1a;http://www.cnblogs.com/446557021/archive/2011/01/05/1926213.html 如果忘记了VSS管理员密码&#xff0c;打开vss数据库所在的文件夹&#xff0c;打开data目录&#xff0c;找到um.dat文件&#xff0c;用编辑器打开编辑它&#xff0c;从offset 80的55 55 开始…

MongoDB文件操作(支持大于4M数据)

// MongoDB连接串&#xff0c;以[mongodb://]开头。这里&#xff0c;我们连接的是本机的服务string connectionString "mongodb://localhost";// 连接到一个MongoServer上MongoServer server MongoServer.Create(connectionString);// 打开数据库testdbMongoDataba…

linux 压缩排除某个文件夹,linux tar压缩排除 某类型文件 某个文件夹

排除某类型文件测试 生成10个.log文件再生成10个.txt文件touch {1..10}.logtouch {1..10}.txt打包并排除 log结尾的文件tar -zcvf 1.tar –exclude*.log . 结论tar -tvf 1.tar rwxr-xr-x root/root 0 2018-10-26 02:45 ./-rw-r–r– root/root 0 2018-1…

oracle之trunc(sysdate)

--截取后得到的仍为date数据类型 select trunc(sysdate) from dual;--2017-03-13 00:00:00select trunc(sysdate1) from dual;--2017-03-14 00:00:00 加一天 select trunc(sysdate,yyyy) from dual;--2017-01-01 00:00:00select trunc(sysdate,MM) from dual;--2017-03-01 00:0…

VS2010 C++下编译调试MongoDB源码 r2.2.2

编译下载mongodb-src-r2.2.2用VS2010打开mongodb-src-r2.2.2\src\mongo\db\db_10.sln编译mongod项目调试先创建数据库文件夹"D:\mongodb\db"设置调试参数--dbpathD:\mongodb\dbF5运行调试

linux如何记录测试时长,如何测试Linux命令运行时间?

如何测试Linux命令运行时间&#xff1f;良许在工作中&#xff0c;写过一个 Shell 脚本&#xff0c;这个脚本可以从 4 个 NTP 服务器轮流获取时间&#xff0c;然后将最可靠的时间设置为系统时间。因为我们对于时间的要求比较高&#xff0c;需要在短时间内就获取到正确的时间。所…

hihocoder offer收割编程练习赛8 B 拆字游戏

思路&#xff1a; 模拟&#xff0c;dfs。 注意题目中的trick&#xff0c;输出一块的时候不要把其他块也输出了。 实现&#xff1a; 1 #include <cstring>2 #include <iostream>3 #include <cstdio>4 #include <algorithm>5 using namespace std;6 7 ch…

linux date 常用格式,5、总结Linux常用命令使用格式,并用实例说明。例如echo、screen、date、ifconfig、export等命令...

COMMAND [OPTIONS...] [ARGUMENTS...]命名 [选项...] [参数...]echo命令功能&#xff1a;显示字符语法&#xff1a;echo [-neE] [字符串]选项&#xff1a;-E (默认)不支持 \ 解释功能-n 不自动换行-e 启用 \ 字符的解释功能显示变量echo "$VAR_NAME" 变量会替换&…

VS2010 C++编译报错LINK : fatal error LNK1123: 转换到 COFF 期间失败: 文件无效或损坏

编译mongodb-src-r2.2.2出现以下问题LINK : fatal error LNK1123: 转换到 COFF 期间失败: 文件无效或损坏这个是由于日志文件引起的&#xff0c;可以将项目\属性\配置属性\清单工具\输入和输出\嵌入清单&#xff1a;原来是“是”&#xff0c;改成“否”。 或者将项目\属性\配置…

软件工程概论个人作业02(四则运算2)

1、设计思想&#xff1a; 在四则运算1的基础上&#xff0c;多加了几个要求&#xff0c;是否有乘除法可以通过不同的选择然随机生成符号的函数有时候生成两个数字对应加减&#xff0c;有时候生成四个数对应加减乘除&#xff1b;括号没有实现&#xff1b;数值范围通过一个函数实现…

linux下怎么将html换成pdf,如何在Linux上使用PHP将HTML/CSS转换为PDF

我一直试图将html页面转换为PDF&#xff0c;但没有任何运气&#xff0c;我尝试使用wkhtmltopdf(http://code.google.com/p/) wkhtmltopdf /)和虽然下面的命令在终端正确执行由相同的开发者(http://code.google.com/p/wkhtmltopdf/wiki/IntegrationWithPhp)中提供的PHP类&#x…

javascript 类型及类型判断

js中的类型&#xff1a; 标准类型&#xff1a;Number、String、Boolean、Null、Undefined 内置对象类型&#xff1a;Function、Array、Date、RegExp、Math、JSON... 类型识别&#xff1a; 1、typeof&#xff1a; 可以识别标准类型&#xff08;Null、Undefined除外&#xf…

linux的yum详解,Linux之YUM 详解

一、yum是什么yum Yellow dog Updater, Modified主要功能是更方便的添加/删除/更新RPM包.它能自动解决包的倚赖性问题.它能便于管理大量系统的更新问题二、yum 的运用格式及常用参数yum [option] "包名"有些记不住的包名 可以使用通配符* 来一次安装多个前端一直的软…

windows 8 安装iis .net 3.5

安装iis要一部分一部分点&#xff08;有些是需要更新包的&#xff09;.net 3.5安装1.将Win8镜像加载到虚拟光驱&#xff1b;或者将 win8 刻录好的光盘插入光驱&#xff1b;2.使用Windows键X,调出命令菜单&#xff0c;选择 命令提示符(管理员)&#xff1b;3.敲入如下命令&#x…