[C++] 化学方程式的格式化算法
网上普遍使用的化学方程式的格式普遍如下
例: KMnO4+FeSO4+H2SO4=Fe2(SO4)3+MnSO4+K2SO4+H2O
要把化学方程式格式化,单单一个正则表达式是非常反人类的,故可选用 C++ 实现化学方程式的格式化。
首先,写一个 for 循环,传入字符数组 input[] ,依次地判断当前字符的位置
然后,声明一个宽字符串: wstring output[]
算法根据循环里的 if 语句判断当前字符是否符合条件,然后把这个字符输出到 output[] 中
for(int i=;i<strlen(input);++i)
{
// Do something...
};
因为传入的字符数组是没有经过格式化的,所以第一个字符一定不用处理,故循环从1开始。
循环开始时,先判断当前的字符是不是空格,如果是空格,就直接无视,跳到下一次的循环。
因为直接跳到了下一次的循环中,所以 input[i] 的字符没有加入到 output 中,也就是自动地把空格给除去了。
然后,在判断当前的字符是否为 +、=、(、) 中的一种,因为这个字符的前后是不可能存在数字下标的,直接加入到输出的 output[] 数组中。
同样的,遇到前一个字符是 +、=、( 也同样直接加入到输出数组中。
实现代码:
for (int i = ;i < strlen(input);++i)
{
if(input[i] == ' ') continue;
if (input[i - ] == '+' || input[i - ] == '='
|| input[i - ] == '(' || input[i] == '+'
|| input[i] == '=' || input[i] == '('
|| input[i] == ')') {
output += input[i];
continue;
}
继续我们的判断,如果当前字符是 A-Z 、 a-z 的,直接加入输出字符数组中。
如果当前字符是数字的,直接将它变成下标。
为了防止 C60 这种由超过 9 个原子组成的分子参与化学反应的情况,所以还要加入一句判断语句来判断。
实现代码:
for (int i = ;i < strlen(input);++i)
{
if(input[i] == ' ') continue;
if (input[i - ] == '+' || input[i - ] == '='
|| input[i - ] == '(' || input[i] == '+'
|| input[i] == '=' || input[i] == '('
|| input[i] == ')') {
output += input[i];
continue;
} if (input[i] >= 'A' && input[i] <= 'Z') {
output += input[i];
continue;
} if (input[i] >= 'a' && input[i] <= 'z') {
output += input[i];
continue;
} if (input[i - ] >= '' && input[i - ] <= '') {
output += input[i];
continue;
} if (input[i] >= '' && input[i] <='')
{
outputBigNumToSmall((int)(input[i]-''));
} }
因为 C++ 标准库并没有把数字转成下标的函数,所以我们要实现一个将数字转成下标的函数
实现代码:
void outputBigNumToSmall(int num)
{
switch (num)
{
case :
output.append(L"₀");
break;
case :
output.append(L"₁");
break;
case :
output.append(L"₂");
break;
case :
output.append(L"₃");
break;
case :
output.append(L"₄");
break;
case :
output.append(L"₅");
break;
case :
output.append(L"₆");
break;
case :
output.append(L"₇");
break;
case :
output.append(L"₈");
break;
case :
output.append(L"₉");
break;
default:
output.append(L"(unknown)");
break;
}
至此,只要输出 output[] 就可以了。
[C++] 化学方程式的格式化算法的更多相关文章
- 一个JS的日期格式化算法示例
一个JS的日期格式化算法. 例子: <script> /** * Js日期格式化算法实例 * by www.jbxue.com */ function dateFormat(date, f ...
- web 前端- 表格字段(文件大小)单位格式化算法
if (value === 0) return '0 B'; var k = 1024, // or 1000 sizes = ['B', 'KB', 'MB ...
- 《设计模式:可复用面向对象软件的基础》【PDF】下载
<设计模式:可复用面向对象软件的基础>[PDF]下载链接: https://u253469.pipipan.com/fs/253469-230382288 内容介绍 <设计模式:可复 ...
- 第一个Hello,OS World操作系统
来自:清泛网 - http://www.tsingfun.com/html/2015/dev_0804/hello_os_word_my_first_os.html 首先阐述下程序运行的基本原理:计算 ...
- Java中日期格式化的实现算法
package com.study.test; import java.io.Serializable; import java.text.SimpleDateFormat; import java. ...
- [C++] 配平化学方程式算法的封装
有人已经实现了配平的方法,在此不再重复介绍. https://www.cnblogs.com/Elfish/p/7631603.html 但是,上述的方法所提供的代码还是存在着问题,需要进一步修改. ...
- C语言之基本算法38—格式化输出10000以内的全部完数
//穷举法! /* ================================================================== 题目:求10000以内的全部完数,统计数量并以 ...
- CSS学习笔记——视觉格式化模型 visual formatting model
CSS 视觉格式化模型(visual formatting model)是用来处理文档并将它显示在视觉媒体上的机制.他有一套既定的规则(也就是W3C规范),规定了浏览器该怎么处理每一个盒子.以下内容翻 ...
- 【EasyUI】 日期格式化
本文经过了测试,解决getFullyear() is not a function等问题 效果如下: 首先: Oracle中字段设置为DATE,MySQL中设置为DATETIME,MyBatis中会自 ...
随机推荐
- 洛谷 P1383 高级打字机==codevs 3333 高级打字机
P1383 高级打字机 18通过 118提交 题目提供者yeszy 标签倍增图论高级数据结构福建省历届夏令营 难度省选/NOI- 提交该题 讨论 题解 记录 最新讨论 暂时没有讨论 题目描述 早苗入手 ...
- text recognizer (OCR) Engine 光学字符识别
https://github.com/tesseract-ocr/tesseract/wiki https://github.com/UB-Mannheim/tesseract/wiki C:\Use ...
- python-----文件自动归类
如何移动文件? → 使用内置模块来实现 归类的规则是什么? → 手动(预设文件夹)/ 自动(创建文件夹) import shutil import os path = './' #由于这里是相对路径 ...
- 洛谷 P2615 神奇的幻方 —— 模拟
题目:https://www.luogu.org/problemnew/show/P2615 直接按题意模拟即可; 用 Emacs 做的第一道题! 代码如下: #include<iostream ...
- TI BLE: Advertisement
#define GAPROLE_ADVERT_ENABLED 0x305 //!< Enable/Disable Advertising. Read/Write. Size is uint8. ...
- ubuntu 16.04 Sqoop 安装
1.下载:https://mirrors.tuna.tsinghua.edu.cn/apache/sqoop/1.4.6/ sqoop-1.4.6.bin__hadoop-2.0.4-alpha.ta ...
- 【154】C#打包程序成安装包
参考0:用C#写完程序怎么用C#打包成安装程序setup自己做的图文说明示例 参考1:解决“默认公司名称” C#打包应用安装后,显示“默认公司名称”,想问问通过哪里可以修改??? 参考2:解决“添加卸 ...
- 疫情控制 2012年NOIP全国联赛提高组(二分答案+贪心)
P1084 疫情控制 题目描述 H 国有 n 个城市,这 n 个城市用 n-1 条双向道路相互连通构成一棵树,1 号城市是首都,也是树中的根节点. H 国的首都爆发了一种危害性极高的传染病.当局为了控 ...
- [C和指针] 6-指针
6.1 内存和地址 我们可以把计算机的内存看作是一条长街上的一排房屋,每座房子都可以容纳数据,并通过一个房号来标识. 这个比喻颇为有用,但也存在局限性.计算机的内存由以亿万计的位(bit)组成,每个位 ...
- [BZOJ3223/Tyvj1729]文艺平衡树
Description 您需要写一种数据结构(可参考题目标题),来维护一个有序数列 其中需要提供以下操作: 翻转一个区间,例如原有序序列是5 4 3 2 1,翻转区间是[2,4]的话,结果是5 2 3 ...