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

例: 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. 【bzoj1507】[NOI2003]Editor

    第二次写rope了 rope大法好!!! #include<algorithm> #include<iostream> #include<ext/rope> #in ...

  2. mongodb配置主从模式

    Mongodb的replication主要有两种:主从和副本集(replica set).主从的原理和mysql类似,主节点记录在其上的所有操作oplog,从节点定期轮询主节点获取这些操作,然后对自己 ...

  3. [Codeforces 986E] Prince's Problem

    [题目链接] https://codeforces.com/contest/986/problem/E [算法] X到Y的路径积 , 可以转化为X到根的路径积乘Y到根的路径积 , 除以LCA到根的路径 ...

  4. SYSUCPC2017 1007 Tutu’s Array II

    题目大意:有A个0和B个1,每次取两个出来进行{XNOR,NAND,NOR}操作生成一个新的0/1,直到只剩一个元素.问最后是否可能剩下一个0,是否可能剩下一个1. XNOR 比较特殊 a XNOR ...

  5. 杂项-Java:MyBatis

    ylbtech-杂项-Java:MyBatis 1.返回顶部 1. MyBatis 本是apache的一个开源项目iBatis, 2010年这个项目由apache software foundatio ...

  6. 21. Ext中表格自适应高度

    转自:https://blog.csdn.net/happy492/article/details/6401099 1. 下面的代码中width和height的初始值为tab的开始大小,当浏览器窗口变 ...

  7. springcloud 向Eureka中注册服务异常java.net.ConnectException: Connection refused: connect

    异常如下: 通过debug发现,服务端的url地址仍然是默认的http://localhost:8761/eureka/apps/,也就是说yml文件中配置没有生效,检查后发现yml中相关配置多写了一 ...

  8. 学习css盒子模型

    在这一周,我学习了css,在没有学习css之前,我一直都觉得布局很难,样式特别难调,但是学习了css盒子模型之后我就觉得欸,其实还挺简单的,下面就来看看我学习的css吧. CSS 盒子模型(Box M ...

  9. GG_DataAccess 数据库访问层使用dapper操作

    3.5.GG_DataAccess 数据库访问层使用dapper操作 和Model实体类同理,tt模板已写好,需要的可加qq群:547765059  自己下载.

  10. redis的持久化的原理介绍和实现

    redis提供了持久化功能——RDB和AOF.通俗的讲就是将内存中的数据写入硬盘中. RDB一定时间取存储文件,AOF默认每秒去存储历史命令,官方建议两种方式同时使用 一.RDB(Redis Data ...