激突要塞代码解阵算法+用C++/Python处理代码
激突要塞的代码长度为6的倍数,其中每6个字符代表着一个单位,这六个字符中,第一位代表着单位的种类,后五位则包含着单位角度.X值.Y值的信息.
那么这个第一位究竟代表什么呢?一图以示之.
那么在代码中就用字典来进行表示了,如果你使用python
name={'v':'骨玉','3':'剑玉','8':'枪玉','a':'剃玉','M':'骑玉','L':'采玉',
'1':'弓玉','7':'弩玉','2':'铳玉','x':'弹玉','b':'跳玉','z':'忍玉',
'c':'裂玉','d':'散玉','B':'花玉','D':'押玉','e':'狙玉','O':'射玉',
'5':'爆玉','9':'炮玉','f':'浮玉','g':'导玉','w':'击玉','N':'核玉',
'k':'飞玉','l':'战玉','K':'旋玉','H':'坠玉','n':'变玉','J':'暗玉',
'6':'魔玉','P':'星玉','S':'查玉','R':'贯玉','m':'机玉','Q':'捆玉',
'4':'盾玉','j':'壁玉','o':'界玉','C':'返玉','E':'迎玉','G':'的玉',
'I':'箱玉','A':'障玉','F':'赘玉','y':'圣玉','h':'缮玉','i':'愈玉',
'p':'木要塞壁','q':'石要塞壁','r':'纸要塞壁','s':'钢要塞壁','t':'红加速','u':'蓝加速',
'T':'近突击','U':'远突击','W':'蓝旋转','V':'紫旋转','X':'狙击壁','Y':'电梯'
}
price={'v':10,'3':30,'8':30,'a':30,'M':150,'L':20,
'1':30,'7':30,'2':70,'x':60,'b':70,'z':70,
'c':70,'d':50,'B':70,'D':60,'e':70,'O':100,
'5':50,'9':70,'f':70,'g':80,'w':70,'N':200,
'k':150,'l':150,'K':150,'H':150,'n':100,'J':150,
'6':200,'P':200,'S':200,'R':150,'m':200,'Q':200,
'4':60,'j':150,'o':90,'C':60,'E':60,'G':50,
'I':70,'A':60,'F':150,'y':200,'h':100,'i':100,
'p':15,'q':40,'r':5,'s':100,'t':100,'u':250,
'T':40,'U':50,'W':80,'V':80,'X':200,'Y':60
}
如果你使用C++
map<string,string>m;
map<string,string>inm;
void init()
{
m["v"]="骨玉";
m["3"]="剑玉";
m["8"]="枪玉";
m["a"]="剃玉";
m["M"]="骑玉";
m["L"]="采玉";
m["1"]="弓玉";
m["7"]="弩玉";
m["2"]="铳玉";
m["x"]="弹玉";
m["b"]="跳玉";
m["z"]="忍玉";
m["c"]="裂玉";
m["d"]="散玉";
m["B"]="花玉";
m["D"]="押玉";
m["e"]="狙玉";
m["O"]="射玉";
m["5"]="爆玉";
m["9"]="炮玉";
m["f"]="浮玉";
m["g"]="导玉";
m["w"]="击玉";
m["N"]="核玉";
m["k"]="飞玉";
m["l"]="战玉";
m["K"]="旋玉";
m["H"]="坠玉";
m["n"]="变玉";
m["J"]="暗玉";
m["6"]="魔玉";
m["P"]="星玉";
m["S"]="查玉";
m["R"]="贯玉";
m["m"]="机玉";
m["Q"]="捆玉";
m["4"]="盾玉";
m["j"]="壁玉";
m["o"]="界玉";
m["C"]="返玉";
m["E"]="迎玉";
m["G"]="的玉";
m["I"]="箱玉";
m["A"]="障玉";
m["F"]="赘玉";
m["y"]="圣玉";
m["h"]="缮玉";
m["i"]="愈玉";
m["p"]="木要塞壁";
m["q"]="石要塞壁";
m["r"]="纸要塞壁";
m["s"]="钢要塞壁";
m["t"]="红加速";
m["u"]="蓝加速";
m["T"]="近突击";
m["U"]="远突击";
m["W"]="蓝旋转";
m["V"]="紫旋转";
m["X"]="狙击壁";
m["Y"]="电梯";
map<string,string>::iterator it=m.begin();
while(it!=m.end())
{
string key=it->first;
string ans=it->second;
inm[ans]=key;
it++;
}
}
好,那么第一位就处理完了,接下来是后五位,我们知道X Y 角度分别是一个三位数.那么把角度+X值+Y值拼接起来就可以了,比如角度270,X值10,Y值280,那么拼接起来就是270010280,在激突要塞的代码中,有52个字母(大小写)和0-9十个阿拉伯数字,那么用62进制表示一下就好了.
demo,和田正一这个密码学鬼才,居然用了一种伪61进制的方法进行表示,爷真的佛了.
在这个进制体系中:
- 0-9就表示0到9
- a到z分别表示10到35
- A到Z分别表示36到61
比如000P6R,就是\(0*61^4+0*61^3+P*61^2+6*61+R-Disp\),得出来的得数,取最右边三位就是Y值,次右边三位就是X值,剩下的就是角度.
注意这个\(DISP\)值
52058 & 单位为要塞时 \\
16020 & 单位为兵玉或者要塞壁时 \\
\end{cases}
\]
我们来看一段激突改阵器(C++)实现的代码
while(s.length()!=0)
{
string type=s.substr(0,1);
string info=s.substr(1,5);
string name;
int angle;
int x;
int y;
if(isYaosai==1)
{
isYaosai=0;
if(type=="0")name="普通要塞";
if(type=="1")name="黑魔王";
angle=0;
int sum=0;
each(i,0,4)
{
int num=0;
char ch=info[i];
//de(ch);
if(ch>='0'&&ch<='9')num=ch-'0';
if(ch>='a'&&ch<='z')num=ch-'a'+10;
if(ch>='A'&&ch<='Z')num=ch-'A'+36;
each(j,1,4-i)num*=61;
sum+=num;
}
sum-=52058;
x=sum/1000;
y=sum%1000;
fprintf(fp,"单位名称,角度,X,Y\n");
fprintf(fp,"%s,%d,%d,%d\n",name.c_str(),angle,x,y);
}
//是兵玉的场合
else{
name=m[type];
int sum=0;
each(i,0,4)
{
int num=0;
char ch=info[i];
//de(ch);
if(ch>='0'&&ch<='9')num=ch-'0';
if(ch>='a'&&ch<='z')num=ch-'a'+10;
if(ch>='A'&&ch<='Z')num=ch-'A'+36;
each(j,1,4-i)num*=61;
sum+=num;
}
sum-=16020;
angle=sum/1000000;
x=(sum%1000000)/1000;
y=sum%1000;
fprintf(fp,"%s,%d,%d,%d\n",name.c_str(),angle,x,y);
}
s=s.substr(6);
}
用途
了解了这些东西,你就可以去整一下有意思的事情比如改阵器(可以改出悬空和倾斜要塞壁的装逼效果),随机阵型生成器甚至AI做阵,不过太难了.
激突要塞代码解阵算法+用C++/Python处理代码的更多相关文章
- 建模分析之机器学习算法(附python&R代码)
0序 随着移动互联和大数据的拓展越发觉得算法以及模型在设计和开发中的重要性.不管是现在接触比较多的安全产品还是大互联网公司经常提到的人工智能产品(甚至人类2045的的智能拐点时代).都基于算法及建模来 ...
- 数据挖掘领域经典分类算法 —— C4.5算法(附python实现代码)
目录 理论介绍 什么是分类 分类的步骤 什么是决策树 决策树归纳 信息增益 相关理论基础 计算公式 ID3 C4.5 python实现 参考资料 理论介绍 什么是分类 分类属于机器学习中监督学习的一种 ...
- 机器学习经典分类算法 —— k-近邻算法(附python实现代码及数据集)
目录 工作原理 python实现 算法实战 约会对象好感度预测 故事背景 准备数据:从文本文件中解析数据 分析数据:使用Matplotlib创建散点图 准备数据:归一化数值 测试算法:作为完整程序验证 ...
- 机器学习经典分类算法 —— k-均值算法(附python实现代码及数据集)
目录 工作原理 python实现 算法实战 对mnist数据集进行聚类 小结 附录 工作原理 聚类是一种无监督的学习,它将相似的对象归到同一个簇中.类似于全自动分类(自动的意思是连类别都是自动构建的) ...
- 算法图解:Python笔记代码
二分查找 选择排序 递归 快速排序 广度优先搜索 狄克斯特拉算法 贪婪算法 二分查找 def binary_search(lst,item): low = 0 high = len(lst)-1 wh ...
- BM算法 Boyer-Moore高质量实现代码详解与算法详解
Boyer-Moore高质量实现代码详解与算法详解 鉴于我见到对算法本身分析非常透彻的文章以及实现的非常精巧的文章,所以就转载了,本文的贡献在于将两者结合起来,方便大家了解代码实现! 算法详解转自:h ...
- Java虚拟机详解04----GC算法和种类【重要】
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
- 4. EM算法-高斯混合模型GMM详细代码实现
1. EM算法-数学基础 2. EM算法-原理详解 3. EM算法-高斯混合模型GMM 4. EM算法-高斯混合模型GMM详细代码实现 5. EM算法-高斯混合模型GMM+Lasso 1. 前言 EM ...
- SSL握手通信详解及linux下c/c++ SSL Socket代码举例(另附SSL双向认证客户端代码)
SSL握手通信详解及linux下c/c++ SSL Socket代码举例(另附SSL双向认证客户端代码) 摘自: https://blog.csdn.net/sjin_1314/article/det ...
随机推荐
- Agentless监控实践中的预警指标采集
很多公司已经开发了监控解决方案,解决了指标收集.展示.预警发送等一系列问题. 本文介绍的监控解决方案由高性能时序数据库InfluxDB.时序分析监控工具Grafana及Agentless自动化工具An ...
- 以股票RSI指标为例,学习Python发送邮件功能(含RSI指标确定卖点策略)
本人之前写过若干“给程序员加财商”的系列文,目的是通过股票案例讲述Python知识点,让大家在学习Python的同时还能掌握相关的股票知识,所谓一举两得. 在之前的系列文里,大家能看到K线,均线,成交 ...
- 【selenium】- selenium IDE的安装以及使用
本文由小编根据慕课网视频亲自整理,转载请注明出处和作者. 1. 自动化测试工程师的任务 一个合格的自动化测试工程师,需要把框架搭建起来.让不是自动化测试的人,一个普通功能化测试的人,可以完成自动化测试 ...
- A-The power of Fibonacci_2019牛客暑期多校训练营(第九场)
题意 求\(\sum_0^n{Fb}_i^m \mod (1e9)\) 题解 模1e9时的斐波那契数列循环节太大,考虑把模数质因数分解成\(2^9\cdot5^9\),此时循环节变成768和78125 ...
- BZOJ2655 Calc - dp 拉格朗日插值法
BZOJ2655 Calc 参考 题意: 给定n,m,mod,问在对mod取模的背景下,从[1,m]中选出n个数相乘可以得到的总和为多少. 思路: 首先可以发现dp方程 ,假定dp[m][n]表示从[ ...
- NOIP2003[提高组] 加分二叉树 题解
题意 给出一个有n个节点的二叉树的中序遍历,以当前节点为根的树的分数等于左节点分数* 右节点分数+根节点分数,叶子节点的分数等于它本身,求最大分数,以及分数最大的树的先序遍历 一道区间dp题,因为要求 ...
- 工作中遇到的99%SQL优化,这里都能给你解决方案(三)
-- 示例表 CREATE TABLE `employees` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(24) NOT NULL ...
- Python中字符编码及转码
python 字符编码及转码 python 默认编码 python 2.X 默认的字符编码是ASCII, 默认的文件编码也是ASCII python 3.X 默认的字符编码是unicode,默认的文件 ...
- 【LeetCode】5# 最长回文子串
题目描述 给定一个字符串 s,找到 s 中最长的回文子串.你可以假设 s 的最大长度为 1000. 示例 1: 输入: "babad" 输出: "bab" 注意 ...
- zookeeper集群部署问题排查记录
今天在三台虚拟机搭建zookeeper集群,一直连不通,然后进行了几个小时的斗争,做个记录. 具体部署方式网上有很多, 不在赘述.产生连接不同的问题主要有以下几个方面: 1.仔细检查配置文件. 是否有 ...