当前位置: 首页 > article >正文

【化学方程式配平 / 3】

题目

代码

#include <bits/stdc++.h>
using namespace std;
const double eps = 1e-8;
unordered_map<string, int> e;
int eidx, midx; //eidx 元素数, midx 物质数
double matrix[45][45];
int q;
bool check_alpha(char c)
{
    if(c >= 'a' && c <= 'z') return true;
    return false;
}
bool gauss(int n, int m)
{
    //if(n < m) return false;
    int c, r, t;
    for(c = 1, r = 1; c <= m; c++)
    {
        t = r;
        for(int i = r+1; i <= n; i++) //找主元
        {
            if(fabs(matrix[i][c]) > fabs(matrix[t][c])) t = i;
        }
        if(fabs(matrix[t][c]) < eps) continue;
        for(int i = c; i <= m+1; i++) //交换
        {
            swap(matrix[r][i], matrix[t][i]);
        }
        for(int i = m+1; i >= c; i--) //归一化
        {
            matrix[r][i] /= matrix[r][c];
        }
        for(int i = r+1; i <= n; i++) //上三角化
        {
            for(int j = m+1; j >= c; j--)
            {
                matrix[i][j] -= matrix[i][c] * matrix[r][j];
            }
        }
        r++;
    }
    if((r-1) < m) return true;
    else return false;
}
int main()
{
    cin >> q;
    while (q -- ){
        memset(matrix, 0, sizeof matrix);
        e.clear();
        eidx = 0;
        cin >> midx;
        
        for(int i = 1; i <= midx; i++)
        {
            string s;
            cin >> s;
            string name = "";
            for(int j = 0; s[j] != '\0'; j++)
            {
                if(!check_alpha(s[j]))
                {
                    string num = "";
                    num += s[j];
                    while(s[++j] != '\0' && !check_alpha(s[j]))
                    {
                        num += s[j];
                    }
                    j--;
                    if(!e.count(name)) e[name] = ++eidx;
                    matrix[e[name]][i] = stoi(num);
                    name = "";
                }
                else name += s[j];
            }
        }
        if(gauss(eidx, midx)) cout << "Y" << endl;
        else cout << "N" << endl;
    }
}


http://www.kler.cn/a/287844.html

相关文章:

  • 近红外简单ROI分析matlab(NIRS_SPM)
  • TCP-IP详解卷 TCP的超时与重传
  • apache-skywalking-apm-10.1.0使用
  • uni-app编写微信小程序使用uni-popup搭配uni-popup-dialog组件在ios自动弹出键盘。
  • iOS - 关联对象的实现
  • SpringBoot之LazyInitializationBeanFactoryPostProcessor类源码学习
  • 网络:IPv6
  • C++:结构体变量可以被多个cpp文件共同使用
  • 大数据系统测试——大数据系统解析(上)
  • 秒级日期空间如何查询整天数据而不是截止到00:00:00到23:59:59?
  • Fabric.js中fabric.Image的深入解析
  • 深入理解Redis(一)----Redis简介+Redis为什么这么快
  • 从中国制造到全球领先,星坤连接器的全球化之路
  • huggingface.co 无法访问问题换源解决
  • Idea中修改Jsp文件的头部注释模版
  • 【LabVIEW学习篇(补充) - 15】:常用快捷键和Quick Drop
  • 版本控制工具git
  • Redis在linux环境集群部署详细介绍
  • 【数据结构】-----哈希
  • 科研绘图系列:R语言富集通路棒棒图(lollipop plot)
  • springboot中根据id查询用户信息
  • 家居设备的多彩世界,乐鑫ESP32芯片模组方案彩屏技术应用,启明云端乐鑫代理商
  • 大文件分块上传和续传
  • LLC电路全桥和半桥工作原理详解
  • 《深入浅出WPF》读书笔记.10资源
  • 鸿蒙开发 ImageKnife二次封装