想要在2026年参加这个比赛的,可以加入小编和其它大佬所建的群242845175一起来备赛,为2026年的比赛打基础,也可以私信小编,为你答疑解惑
在这里插入图片描述

一、读取文件

这里有两种文件需要读取,所以要额外处理

internal class Read
{public static List<Point> Points = new List<Point>();public static List<Point> BLdms = new List<Point>();public static List<Point> Newmap = new List<Point>();public static List<Point> ReadfileBL(string filename){string str;StreamReader sr = new StreamReader(filename);while(!sr.EndOfStream){str = sr.ReadLine();string[]Buf= str.Split(new char[] { ',', '\t', ' ' }, StringSplitOptions.RemoveEmptyEntries);Point pt=new Point(Buf[0], double.Parse(Buf[1]), double.Parse(Buf[2]));Points.Add(pt);BLdms.Add(pt);}return Points;}public static List<Point> ReadfileNewmap(string filename){string str;StreamReader sr = new StreamReader(filename);while (!sr.EndOfStream){str = sr.ReadLine();string[] Buf = str.Split(new char[] { ',', '\t', ' ' }, StringSplitOptions.RemoveEmptyEntries);Point pt = new Point(int.Parse(Buf[0]), Buf[1]);Points.Add(pt);Newmap.Add(pt);}return Points;}
}

二、度与dms之间的转化

public static double dL_100w = dms_rad(6);
public static double dB_100w = dms_rad(4);
public static double dL_50w=dms_rad(3);
public static double dB_50w=dms_rad(2);
public static double dL_25w = dms_rad(1.30);
public static double dB_25w = dms_rad(1);
public static double dL_10w = dms_rad(0.30);
public static double dB_10w = dms_rad(0.20);
public static double dL_5w = dms_rad(0.15);
public static double dB_5w = dms_rad(0.10);
public static double dL_2d5w = dms_rad(0.073);
public static double dB_2d5w = dms_rad(0.05);
public static double dL_1w = dms_rad(0.0345);
public static double dB_1w = dms_rad(0.0230);
public static double dL_5k = dms_rad(0.01525);
public static double dB_5k = dms_rad(0.0115);
public static double dL_2k = dms_rad(0.00375);
public static double dB_2k = dms_rad(0.0025);
public static double dL_1k = dms_rad(0.001875);
public static double dB_1k = dms_rad(0.00125);
public static double dL_5b = dms_rad(0.0009375);
public static double dB_5b = dms_rad(0.000625);//dms转化为度进制
public static double dms_rad(double dms)
{int a = (int)dms;double b = (int)((dms - a) * 100) * 60;double c = ((int)(dms * 10000 % 100) + b) / 3600;return (a+c);}
//十进制转化为dms
public static double rad_dms(double rad)
{double d = (int)rad;double m = (int)((rad - d) * 60);double s = ((rad - d) * 60 - m) * 60;double dms = d + m / 100 + s / 10000;if (s >= 59.999)//出现了 115度30分60秒的结果错误{dms = dms - 0.0060 + 0.01;if (m + 1 >= 59.999){dms = dms + 1 - 0.60;}}return dms;
}

三、经纬度转化为新版图幅

在这里插入图片描述

 public static void avg(){double sumb = 0;double suml = 0;for (int i = 0; i < Read.BLdms.Count; i++){sumb += Read.BLdms[i].B_dms;suml += Read.BLdms[i].L_dms;}Point avgpt = new Point("avg", sumb / Read.BLdms.Count, suml / Read.BLdms.Count);Read.BLdms.Add(avgpt);}public static void Selectnumber(double scale,out double dertaB,out double dertaL,out string sc){dertaB = 0;dertaL = 0;sc = null;switch (scale){case 1000000:dertaB = dB_100w;dertaL=dL_100w;sc = "A";break;case 500000:dertaB = dB_50w;dertaL=dL_50w;sc = "B";break;case 250000:dertaB = dB_25w;dertaL=dL_25w;sc = "C";break;case 100000:dertaB = dB_10w;dertaL=dL_10w;sc = "D";break;case 50000:dertaB = dB_5w;dertaL=dL_5w;sc = "E";break;case 25000:dertaB = dB_2d5w;dertaL=dL_2d5w;sc = "F";break;case 10000:dertaB = dB_1w;dertaL=dL_1w;sc = "G";break;case 5000:dertaB = dB_5k;dertaL = dL_5k;sc = "H";break;case 2000:dertaB = dB_2k;dertaL=dL_2k;sc = "I";break;case 1000:dertaB = dB_1k;dertaL=dL_1k;sc = "J";break;case 500:dertaB = dB_5b;dertaL=dL_5b;sc = "K";break;}}//把经纬度转化为新版图幅public static void Bl_newmap(Point point){Selectnumber(point.scale, out double dertaB, out double dertaL,out string sc);int a = (int)(point.B_rad / 4) + 1;char c = (char)(a - 'A' + 1);int b = (int)(point.L_rad / 6) + 31;int m = (int)((point.L_rad % 6)/dertaL)+1;string e = m.ToString();string f = null;string h = null;int n =(int) (4/dertaB)-(int)((point.B_rad % 4)/dertaB);string g=n.ToString();if (point.scale == 1000 || point.scale == 500){f = e.PadLeft(4, '0');h = g.PadLeft(4, '0');}else{f = e.PadLeft(3, '0');h = g.PadLeft(3, '0');}point.newmap=a.ToString()+b.ToString()+sc.ToString()+h.ToString()+f.ToString(); }

四、新版图幅转化为西南角经纬度

在这里插入图片描述

public static void Selectid(string id, out double dertaB, out double dertaL, out double scale)
{dertaB = 0;dertaL = 0;scale = 0;switch (id){case "A":dertaB = dB_100w;dertaL = dL_100w;scale = 1000000;break;case "B":dertaB = dB_50w;dertaL = dL_50w;scale = 500000;break;case "C":dertaB = dB_25w;dertaL = dL_25w;scale = 250000;break;case "D":dertaB = dB_10w;dertaL = dL_10w;scale = 10000;break;case "E":dertaB = dB_5w;dertaL = dL_5w;scale=50000;break;case "F":dertaB = dB_2d5w;dertaL = dL_2d5w;scale = 25000;break;case "G":dertaB = dB_1w;dertaL = dL_1w;scale = 10000;break;case "H":dertaB = dB_5k;dertaL = dL_5k;scale = 5000;break;case "I":dertaB = dB_2k;dertaL = dL_2k;scale = 2000;break;case "J":dertaB = dB_1k;dertaL = dL_1k;scale = 1000;break;case "K":dertaB = dB_5b;dertaL = dL_5b;scale = 500;break;}}public static void Nmap_bl(Point point)
{string nem = point.newmap;int line_100 = (int)(nem[0] - 'A' + 1);int up_100=int.Parse(nem.Substring(1,2));point.lin_100=line_100;point.u_100=up_100;point. B_100=(line_100-1) * 4;point. L_100 = (up_100 - 31) * 6;string c = nem[3].ToString();Selectid(c, out double dertaB, out double dertaL, out double scale);point.scale = scale;int n=(int)(4/dertaB);double cc = 0;double d = 0;if (point.scale == 1000 || point.scale == 500){cc=int.Parse(nem.Substring(4,4));d=int.Parse(nem.Substring(8, 4));}else{cc = int.Parse(nem.Substring(4, 3));d = int.Parse(nem.Substring(7, 3));}point.leftdownB=point.B_100+dertaB*(n-cc);point.leftdownL = point.L_100 + dertaL * (d - 1);point.rightdownB = point.leftdownB;point.rightdownL = point.leftdownL + dertaL;point.leftupB = point.leftdownB + dertaB;point.leftupL = point.leftdownL;point.rightupL = point.leftdownL + dertaL;point.rightupB=point.leftdownB + dertaB;
}

五、事件交互

public partial class Form1 : Form
{public Form1(){InitializeComponent();openFile.FileOk += openFile_FileOk;}public static List<Point> bBLdms= new List<Point>();public static List<Point> bNewmap= new List<Point>();public string report = null;private void openFile_FileOk(object sender, CancelEventArgs e){}private void toolStripLabel1_Click(object sender, EventArgs e){if(openFile.ShowDialog() == DialogResult.OK){string file=openFile.FileName;Read.ReadfileBL(file);bBLdms=Read.BLdms;dataGridView1.RowCount = bBLdms.Count;for(int i=0;i<bBLdms.Count;i++) {dataGridView1[0, i].Value = bBLdms[i].name;dataGridView1[2, i].Value = bBLdms[i].B_dms;dataGridView1[3, i].Value = bBLdms[i].L_dms;}}}private void toolStripLabel2_Click(object sender, EventArgs e){if (openFile.ShowDialog() == DialogResult.OK){string file = openFile.FileName;Read.ReadfileNewmap(file);bNewmap = Read.Newmap;dataGridView2.RowCount = bNewmap.Count;for (int i = 0; i < bNewmap.Count; i++){dataGridView2[1, i].Value = bNewmap[i].ID;dataGridView2[4, i].Value = bNewmap[i].newmap;}}}private void toolStripLabel3_Click(object sender, EventArgs e){Alth.avg();report +=  Read.BLdms[0].L_dms.ToString("F5")+"\n";report += Read.BLdms[2].B_dms.ToString("F5")+"\n";report += Read.BLdms[2].L_rad.ToString("F6")+"\n";report += Read.BLdms[2].B_rad.ToString("F6") + "\n";report += Alth.rad_dms(Read.BLdms[3].B_rad).ToString("F6") + "\n";report += Alth.rad_dms(Read.BLdms[3].L_rad).ToString("F6") + "\n";report += Read.BLdms[3].B_rad.ToString("F6") + "\n";report += Read.BLdms[3].L_rad.ToString("F6") + "\n";Read.BLdms[3].scale = 250000;Alth.Bl_newmap(Read.BLdms[3]);report += Read.BLdms[3].newmap.Substring(4, 3)+"\n";report += Read.BLdms[3].newmap.Substring(7, 3)+"\n";Read.BLdms[3].scale = 500;Alth.Bl_newmap(Read.BLdms[3]);report += Read.BLdms[3].newmap.Substring(4, 4) + "\n";report += Read.BLdms[3].newmap.Substring(8, 4) + "\n";richTextBox1.Text = report;}private void toolStripLabel5_Click(object sender, EventArgs e){Alth.Nmap_bl(Read.Newmap[0]);report += Read.Newmap[0].lin_100 + "\n";report += Read.Newmap[0].u_100 + "\n";Alth.Nmap_bl(Read.Newmap[1]);report += Read.Newmap[1].lin_100 + "\n";report += Read.Newmap[1].u_100 + "\n";report += Read.Newmap[0].scale + "\n";report += Read.Newmap[1].scale + "\n";report += Alth.rad_dms(Read.Newmap[0].leftdownL).ToString("F5")+ "\n";report += Alth.rad_dms(Read.Newmap[0].leftdownB).ToString("F5") + "\n";report += Alth.rad_dms(Read.Newmap[1].leftdownL).ToString("F5") + "\n";report += Alth.rad_dms(Read.Newmap[1].leftdownB).ToString("F5") + "\n";report += Alth.rad_dms(Read.Newmap[0].rightdownL).ToString("F5") + "\n";report += Alth.rad_dms(Read.Newmap[0].rightdownB).ToString("F5") + "\n";report += Alth.rad_dms(Read.Newmap[0].rightupL).ToString("F5") + "\n";report += Alth.rad_dms(Read.Newmap[0].rightupB).ToString("F5") + "\n";report += Alth.rad_dms(Read.Newmap[0].leftupL).ToString("F5") + "\n";report += Alth.rad_dms(Read.Newmap[0].leftupB).ToString("F5") + "\n";report += Alth.rad_dms(Read.Newmap[1].rightdownL).ToString("F5") + "\n";report += Alth.rad_dms(Read.Newmap[1].rightdownB).ToString("F5") + "\n";report += Alth.rad_dms(Read.Newmap[1].rightupL).ToString("F5") + "\n";report += Alth.rad_dms(Read.Newmap[1].rightupB).ToString("F5") + "\n";report += Alth.rad_dms(Read.Newmap[1].leftupL).ToString("F5") + "\n";report += Alth.rad_dms(Read.Newmap[1].leftupB).ToString("F5") + "\n";richTextBox1.Text = report;}private void toolStripLabel4_Click(object sender, EventArgs e){SaveFileDialog sf = new SaveFileDialog();sf.Filter = "文本数据|*.txt";sf.Title = "选择保存路径";sf.FileName = "result";if(sf.ShowDialog() == DialogResult.OK){StreamWriter sw = new StreamWriter(sf.FileName);sw.Write(report);sw.Flush();}}
}

六、页面布局

在这里插入图片描述

七、结果

114.12353
35.30250
116.483333
35.506944
34.103300
116.022600
34.175833
116.040556
002
002
1095
0817
10
50
9
50
50000
10000
116.00000
39.50000
119.52300
32.40000
116.15000
39.50000
116.15000
40.00000
116.00000
40.00000
119.56150
32.40000
119.56150
32.42300
119.52300
32.42300

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

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

相关文章

【C++基础】名字空间与 inline 命名空间:面试高频考点与真题解析

想象一下,你正在开发一个大型项目,团队中有10名程序员同时工作。当你们分别定义了calculate()函数时,编译器会陷入混乱:它不知道应该调用哪个版本的calculate。这就是C++引入名字空间(Namespace)的根本原因! 一、名字空间(Namespace)基础概念 1.1 为什么需要名字空间…

Pytest项目_day08(setup、teardown前置后置操作)

setup模块级setup_module&#xff1a;运行于模块开始之前&#xff0c;生效一次 一个py文件&#xff08;测试文件&#xff09;就是一个模块函数级setup_function&#xff1a;对于每条&#xff08;不在类中的&#xff09;函数用例生效&#xff0c;如果函数在类中&#xff0c;那么…

trae开发c#

安装插件C# Dev Kit&#xff0c;使用的版本是1.41.11 .NET Install Tool一般会自动安装&#xff0c;安装C# dev kit的时候&#xff0c;版本2.3.7 C# 插件&#xff0c;版本2.87.31 https://marketplace.visualstudio.com/items?itemNamems-dotnettools.vscode-dotnet-runtim…

Modstart 请求出现 Access to XMLHttpRequest at ‘xx‘

在 uniapp 前端页面请求时出现类似如下错误Access to XMLHttpRequest at https://example.com/api/mtiku/config from origin http://localhost:20000 has been blocked by CORS policy: Response to preflight request doesnt pass access control check: No Access-Control…

计算机视觉CS231n学习(5)

循环神经网络 RNN recurrent neural networksRNN序列处理能力&#xff08;RNN核心作用&#xff09; RNN处理序列数据&#xff0c;相比“Vanilla”神经网络&#xff08;仅支持一对一映射&#xff09;&#xff0c;RNN支持多种序列映射模式&#xff1a; 一对一&#xff1a;传统分类…

Spring Boot Redis 缓存完全指南

Spring Boot Redis 缓存完全指南 1. 项目依赖配置 1.1 Maven依赖 <dependencies><!-- Spring Boot Redis --><dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-data-redis</artifactId><…

八股——WebSocket

文章目录1、 什么是 WebSocket&#xff1f;与 Http 协议的区别是什么&#xff1f;2、 Http 是如何升级为 WebSocket 的&#xff1f;3、 为什么 WebSocket 可以进行全双工模式的消息传输&#xff0c;而 Http 不可以&#xff1f;4、 什么是 TCP 的沾包和拆包&#xff1f;5、 WebS…

Mysql 如何使用 binlog 日志回滚操作失误的数据

文章目录一、背景二、准备测试数据1. 创建测试表2. 创建测试数据三、模拟误操作四、数据回滚&#xff08;一&#xff09;方案一&#xff1a;云数据库恢复&#xff08;二&#xff09;方案二&#xff1a;手动恢复1. 查询 binlog 日志2. 找到删除语句&#xff0c;手动还原为插入语…

wodpress结构化数据对SEO的作用

在 WordPress 网站中&#xff0c;结构化数据对 SEO 的作用主要体现在以下几个方面&#xff1a; 1. 提升搜索结果的可见性 结构化数据能够帮助搜索引擎更好地理解网页内容&#xff0c;从而以更精准的方式展示搜索结果。通过添加结构化数据&#xff0c;网页可以在搜索结果中显示…

讲一讲@ImportResource

题目详细答案ImportResource是 Spring 框架中的一个注解&#xff0c;用于将传统的 XML 配置文件导入到基于 Java 配置的 Spring 应用程序中。它允许开发者在使用 Java 配置的同时&#xff0c;继续利用现有的 XML 配置文件。这样可以逐步迁移旧的 XML 配置&#xff0c;或者在某些…

解决 Nginx 反代中 proxy_ssl_name 环境变量失效问题:网页能打开但登录失败

前言&#xff1a;在现代企业架构中&#xff0c;多域名反向代理是实现业务隔离、品牌独立的常见方案。然而&#xff0c;看似简单的Nginx配置背后&#xff0c;隐藏着与TLS协议、后端认证逻辑深度绑定的细节陷阱。本文将从原理到实践&#xff0c;详解为何在多域名场景下&#xff0…

三步完成,A100本地vLLM部署gpt-oss,并启动远程可访问api

A100本地vLLM部署gpt-oss&#xff0c;并启动远程可访问api GPT-oss试用 gpt-oss有两个原生配置是目前&#xff08;2025-8-8&#xff09;Ampere系列显卡不支持的&#xff0c;分别是默认的MXFP4量化&#xff0c;以及Flash-attn V3。官方给出的vllm教程也是默认使用的是H系列显卡…

【华为机试】63. 不同路径 II

文章目录63. 不同路径 II题目描述示例 1&#xff1a;示例 2&#xff1a;提示&#xff1a;解题思路核心思想&#xff1a;动态规划&#xff08;避开障碍&#xff09;算法流程复杂度分析边界与细节方法对比代码实现Go 实现&#xff08;含二维DP / 一维DP / 记忆化&#xff09;测试…

C++ 模拟实现 map 和 set:掌握核心数据结构

C 模拟实现 map 和 set&#xff1a;掌握核心数据结构 文章目录C 模拟实现 map 和 set&#xff1a;掌握核心数据结构一、set 和 map 的结构1.1 set的结构1.2 map的结构二、对红黑树的改造2.1 改造红黑树的节点2.2 改造红黑树2.2.1 仿函数的使用2.2.2 插入函数的改造2.2.3 删除函…

根据ASTM D4169-23e1标准,如何选择合适的流通周期进行测试?

根据ASTM D4169-23e1标准及行业实践&#xff0c;选择流通周期&#xff08;DC&#xff09;需综合以下因素&#xff1a;一、核心选择依据‌产品属性与包装形式‌‌重量体积‌&#xff1a;轻小包裹&#xff08;<4.53kg且<0.056m&#xff09;适用DC2/3/4/6/9/13-17等周期&…

MySQL的触发器:

目录 触发器的概念&#xff1a; 创建触发器&#xff1a; 查看触发器&#xff1a; 查看当前数据库的所有触发器的定义&#xff1a; 查看当前数据中某个触发器的定义&#xff1a; 从系统information_schema的TRIGGERS表中查询"salary_check_trigger"触发器的信息…

基于ubuntu搭建gitlab

原文地址&#xff1a;基于ubuntu搭建gitlab – 无敌牛 欢迎参观我的网站&#xff1a;无敌牛 – 技术/著作/典籍/分享等 之前介绍了一个使用 git openssh-server 搭建一个极简 git 库的方法&#xff0c;感兴趣可以查看往期文章&#xff1a;手搓一个极简远端git库 – 无敌牛 。…

测试GO前沿实验室:为水系电池研究提供多维度表征解决方案

测试GO前沿实验室&#xff1a;为水系电池研究提供多维度表征解决方案随着全球能源转型加速&#xff0c;水系电池因其高安全性、低成本和环境友好特性&#xff0c;成为下一代储能技术的重要发展方向。测试狗前沿实验室针对水系电池研发中的关键科学问题&#xff0c;整合先进表征…

Spring Boot 中 YAML 配置文件详解

Spring Boot 中 YAML 配置文件详解 在 Spring Boot 项目中&#xff0c;配置文件是不可或缺的一部分&#xff0c;用于自定义应用行为、覆盖默认设置。除了传统的 properties 文件&#xff0c;Spring Boot 对 YAML&#xff08;YAML Ain’t Markup Language&#xff09;格式提供了…

Milvus安装可视化工具,attu,保姆级

安装包链接&#xff1a;GitHub - zilliztech/attu: Web UI for Milvus Vector Databasehttps://github.com/zilliztech/attu?tabreadme-ov-file 下滑 举例&#xff1a;windows&#xff1a;下载安装&#xff0c;然后就可以连接了&#xff08;安装完打开后如果需要输入用户名密码…