网上普遍使用的化学方程式的格式普遍如下

例: 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++] 化学方程式的格式化算法的更多相关文章

  1. 一个JS的日期格式化算法示例

    一个JS的日期格式化算法. 例子: <script> /** * Js日期格式化算法实例 * by www.jbxue.com */ function dateFormat(date, f ...

  2. web 前端- 表格字段(文件大小)单位格式化算法

                     if (value === 0) return '0 B';   var k = 1024, // or 1000   sizes = ['B', 'KB', 'MB ...

  3. 《设计模式:可复用面向对象软件的基础》【PDF】下载

    <设计模式:可复用面向对象软件的基础>[PDF]下载链接: https://u253469.pipipan.com/fs/253469-230382288 内容介绍 <设计模式:可复 ...

  4. 第一个Hello,OS World操作系统

    来自:清泛网 - http://www.tsingfun.com/html/2015/dev_0804/hello_os_word_my_first_os.html 首先阐述下程序运行的基本原理:计算 ...

  5. Java中日期格式化的实现算法

    package com.study.test; import java.io.Serializable; import java.text.SimpleDateFormat; import java. ...

  6. [C++] 配平化学方程式算法的封装

    有人已经实现了配平的方法,在此不再重复介绍. https://www.cnblogs.com/Elfish/p/7631603.html 但是,上述的方法所提供的代码还是存在着问题,需要进一步修改. ...

  7. C语言之基本算法38—格式化输出10000以内的全部完数

    //穷举法! /* ================================================================== 题目:求10000以内的全部完数,统计数量并以 ...

  8. CSS学习笔记——视觉格式化模型 visual formatting model

    CSS 视觉格式化模型(visual formatting model)是用来处理文档并将它显示在视觉媒体上的机制.他有一套既定的规则(也就是W3C规范),规定了浏览器该怎么处理每一个盒子.以下内容翻 ...

  9. 【EasyUI】 日期格式化

    本文经过了测试,解决getFullyear() is not a function等问题 效果如下: 首先: Oracle中字段设置为DATE,MySQL中设置为DATETIME,MyBatis中会自 ...

随机推荐

  1. 洛谷 P1759 通天之潜水

    P1759 通天之潜水 19通过 65提交 题目提供者lych 标签动态规划洛谷原创 难度普及/提高- 提交该题 讨论 题解 记录 最新讨论 暂时没有讨论 题目背景 直达通天路·小A历险记第三篇 题目 ...

  2. {转}Python IDLE中文乱码

    http://hi.baidu.com/yobin/item/166e3a46537781d3c1a59257 乱码原因:因为你的文件声明为utf-8,并且也应该是用utf-8的编码保存的源文件.但是 ...

  3. luogu2540 斗地主增强版

    题目大意 给你一副手牌,没有飞机带翅膀,按斗地主的规则,求将所有牌打出的最少次数. 题解 先不考虑顺子 我们已经知道花色对牌没有影响,那么如果不考虑顺子,每个牌具体是什么数字我们也用不着知道,我们关心 ...

  4. Minimizing Maximizer

    题意: 最少需要多少个区间能完全覆盖整个区间[1,n] 分析: dp[i]表示覆盖[1,i]最少需要的区间数,对于区间[a,b],dp[b]=min(dp[a...b-1])+1;用线段树来维护区间最 ...

  5. CSU 1807: 最长上升子序列~ 分类讨论

    1807: 最长上升子序列~ Time Limit: 5 Sec  Memory Limit: 128 MBSubmit: 138  Solved: 17[Submit][Status][Web Bo ...

  6. android中设置控件获得焦点

    android中,要使控件获得焦点,需要先setFocus,再requestFocus. 以Button为例:                btn.setFocusable(true);       ...

  7. BZOJ_3667_Rabin-Miller算法_Mille_Rabin+Pollard rho

    BZOJ_3667_Rabin-Miller算法_Mille_Rabin+Pollard rho Description Input 第一行:CAS,代表数据组数(不大于350),以下CAS行,每行一 ...

  8. JS复制文件(转)

    <script type="text/javascript"> var fso, f; function copyFile() { fso = new ActiveXO ...

  9. C#面向过程之局部变量、成员变量、变量作用域、可变参数

    局部变量与成员变量:  局部变量:定义在方法里面的变量就叫做局部变量:没有默认的初始值,使用变量之前必须给它赋值成员变量:定义在类下面的变量叫做成员变量:如果是数值类型默认初始值为0 如果是引用类型默 ...

  10. MySQL基础 — 常用命令

    一.连接MySQL 格式: mysql -h主机地址 -u用户名 -p用户密码 1.连接到本机上的MySQ: 首先在打开cmd窗口,输入mysql -uroot -p ,然后空格进入MySQL控制台, ...