IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> C++知识库 -> CCF-CSP认证 201912-3 化学方程式 -> 正文阅读

[C++知识库]CCF-CSP认证 201912-3 化学方程式

CCF-CSP认证 201912-3 化学方程式

题意描述

给出n个化学方程式 让我们判断化学方程式是否配平

输入输出格式

输入第一行包含一个整数n表示方程式的数量 接下来是n行化学方程式

数据规模

n在[1,100] 之间

算法设计

个人认为 这应该是CSP第三题中最好读懂题意的题目了 就是给几个化学方程式 让我们去判断方程式是否配平 直接上字符串处理 但是说来容易 仔细想一想 我们需要考虑的细节还是不少的 我列出了以下需要解决的问题 以及相应的解决方案

  1. 如何去判断方程式是平的?
    我们建立一张图 map<string,gg> gg 即是 long long 用来统计元素出现的次数 方程式等号左边出现的元素使得该元素在图中的计数++ 而右边的元素使得该计数-- 最后遍历 map 只要有元素的个数不为0 即为方程式不平 反之 方程式就是配平的
  2. 以什么为处理的单位?
    在这里我们以一个表达式作为处理的单位 将字符串用+号分割 分割出来的即是表达式 这里的表达式可以是H2 H20 Cu(OH)2 我们单独编写函数来处理这样的表达式
  3. 数字的处理?
    在处理函数中 开始必须计算整个表达式的总系数 而对于每个元素 它的个数便是总系数乘以元素后面的数字 我们单独编写函数来处理数字 而且 参数是引用类型 方便我们处理下一个表达式
  4. 括号的处理?
    这里便体现了我们以表达式作为处理对象的好处了 比如Cu(OH)2 这里括号包裹的显然也是一个表达式 只不过这个表达式的初始系数等于原来的系数 乘以 括号后面的系数 那我们显然可以递归地调用处理表达式的函数

模拟题比较繁琐 希望读者可以耐心地在这些问题的引导下 自己独立编码实现 调试 解决bug 我在代码里添加了一定的注释 希望对实现有所帮助

c++11代码

#include <bits/stdc++.h>
using namespace std;
using gg = long long;
unordered_map<string, gg> mp;//  全局图
gg computenum(const string& s,gg& start){  // start是数字的开头 显然 计算过后的start 指向的不再是数字
    gg res = 0;   //  初值为0
    while(start<s.size() and isdigit(s[start])){
        res = res * 10 + (s[start] - '0');
        start++;
    }
    return (res == 0 ? 1 : res);   //  总系数不能是0啊!
}

void deal(const string& s,gg e){  // 开始考虑单个字符的计算  e 是这个表达式的总系数  快慢指针处理字符串
    gg i = 0, j;  // i是处理字符的起点
    e *= computenum(s, i);   // 计算总系数
    while(i < s.size()){
        if(isupper(s[i])){  // 确定是一个元素了
            if(i+1 < s.size() and islower(s[i+1])){     // 双原子元素
                gg k = i;
                i += 2;  // 指向元素后面的数字
                mp[s.substr(k, 2)] += e * computenum(s,i);   // 此时 i以及指向了下一个判断位了
            }else{   // 单原子元素
                gg k = i;
                i += 1;
                mp[s.substr(k, 1)] += e * computenum(s, i);
            }
        }else{    // 不是元素 开始考虑括号    其实 括号的内部 就是一个结果相同的表达式
            gg left = i, right = i + 1, num = 1; // 开始寻找括号的右边界   处理区间即为[left+1,right-1]
            while(num!=0 and right < s.size()){
                if(s[right] == '(')
                    num++;
                else if(s[right] == ')')
                    num--;
                right++;
            }
            deal(s.substr(left + 1, right - left - 2), e * computenum(s, right));
            i = right;
        }
    }
}

void compute(const string& s,gg exp){   // 把整个表达式进行了分割
    gg i, j;
    for (i = 0; i < s.size();){
        j = s.find('+', i);
        if(j == string::npos){
            deal(s.substr(i),exp);
            i = s.size();
        }else{
            deal(s.substr(i, j - i),exp); // 第二参数是子串的长度
            i = j + 1;
        }
    }
}
int main()
{
    ios::sync_with_stdio(false);
    cin.tie(0);
    gg ni;
    cin >> ni;
    string s;
    while (ni--){
        cin >> s; //   要处理的化学方程式
        auto j = s.find('=');
        compute(s.substr(0, j), 1); // 计算左边
        compute(s.substr(j + 1),-1);   //  计算右边  右边要减去 参数是 -1 
        for(auto i : mp){
           if(i.second !=0){
               cout << "N\n";
               goto loop;
           }
        }
        cout << "Y\n";
        loop:;
        mp.clear();   // 图一定要清空!
   }
   return 0;
}

题目链接

  C++知识库 最新文章
【C++】友元、嵌套类、异常、RTTI、类型转换
通讯录的思路与实现(C语言)
C++PrimerPlus 第七章 函数-C++的编程模块(
Problem C: 算法9-9~9-12:平衡二叉树的基本
MSVC C++ UTF-8编程
C++进阶 多态原理
简单string类c++实现
我的年度总结
【C语言】以深厚地基筑伟岸高楼-基础篇(六
c语言常见错误合集
上一篇文章      下一篇文章      查看所有文章
加:2021-08-14 13:50:50  更:2021-08-14 13:51:48 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/21 4:48:01-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码