【CCF-CSP】202403-3 化学方程式配平

 

输入格式:

从标准输入读入数据。

输入的第一行包含一个正整数 n,表示需要判断的化学方程式的个数。

接下来的 n 行,每行描述了一个需要被配平的化学方程式。包含空格分隔的一个正整数和全部涉及物质的化学式。其中,正整数 m 表示方程式中的物质;随后的 m 个字符串,依次给出方程式中的反应物的化学式和生成物的化学式。

输出格式:

输出到标准输出。

输出包含 n 行,每行包含字母 Y 或 N,表示按题设方法,所给待配平化学方程式能否配平。

提示:

  • 对矩阵进行高斯消元的一种方法是:

    1. 考察矩阵的第一列上的元素:
      • 若全都为零,则对除去该列的子矩阵重复上述判断;
      • 若不全为零,则:
        1. 考察第一行第一列的元素:
          • 如果其为 0,则将该行与后面的某一个第一列非 0 的行交换,使第一行第一列的元素非 0;
        2. 令后续所有行减去第一行的适当倍数,使得后续所有行的第一列元素为 0;
    2. 对除去第一行第一列的子矩阵重复上述操作,直至不再余下子矩阵。
  • 对系数矩阵高斯消元后,不全为 0 的行的数目即为系数矩阵的秩。

  • 评测环境仅提供各语言的标准库,特别地,不提供任何线性代数库。

思路:

这是一道比较简单的矩阵运算题,但是矩阵的那些专业术语我也不太记得了,代码里面就直接写运算的步骤了,如果需要的话,可以去回顾一下阶梯型矩阵化简的方法。

代码:

#include <bits/stdc++.h>
#define N 50
using namespace std;int n,m,cnt,r;//cnt是元素个数,r是矩阵的秩
double a[N][N];//矩阵系数
string s;
map<string,int> mp;//记录元素的编号void fun(int id){//对物质的每个元素进行统计string name=""; //元素名int c=0; //元素右边的系数for(int i=0;i<s.size();i++){if(isdigit(s[i])){int j=i; //获得元素右边的系数while(j<s.size()&&isdigit(s[j])) c=c*10+s[j++]-'0';i=j-1;int k; //元素编号if(mp.count(name)) k=mp[name]; //前面出现过else k=mp[name]=++cnt; //没出现过a[k][id]=c; //每个元素在矩阵中是一行,一共有m列,m是物质(未知量)个数name="";c=0;}else name+=s[i]; //元素名}}
void solve(){memset(a,0,sizeof a);cnt=0;mp.clear();cin>>m;for(int i=1;i<=m;i++){cin>>s;fun(i);//对每个物质的元素进行统计}for(int i=1;i<=cnt+1;i++){ //矩阵行运算,到cnt+1,便于统计边界int fg=0;for(int j=i;j<=cnt;j++){ //选择一个第i列不为0的行if(abs(a[j][i])>1e-6){fg=j;break;}}if(!fg){ //如果没有,那就结束了r=i-1;break;}for(int k=1;k<=m;k++) swap(a[i][k],a[fg][k]);//交换两行for(int j=i+1;j<=cnt;j++){//后面的行 用矩阵行相加运算把这一列的值变为0if(a[j][i]>0){double c=a[j][i]/a[i][i];for(int k=i;k<=m;k++) a[j][k]-=c*a[i][k];}}}if(r<m) cout<<"Y"<<endl;else cout<<"N"<<endl; 
}
int main(){cin>>n;while(n--){solve();}return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/3029728.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

KMeans,KNN,Mean-shift算法的学习

1.KMeans算法是什么&#xff1f; 在没有标准标签的情况下&#xff0c;以空间的k个节点为中心进行聚类&#xff0c;对最靠近他们的对象进行归类。 2.KMeans公式&#xff1a; 2. 1.关键分为三个部分&#xff1a; 1.一开始会定义n个中心点&#xff0c;然后计算各数据点与中心点…

企业活动想联系媒体报道宣传如何联系媒体?

在企业的宣传推广工作中,我曾经历过一段费事费力、效率极低的时期。那时,每当公司有重要活动或新项目需要媒体报道时,我便要一家家地联系媒体,发送邮件、打电话,甚至亲自登门拜访,只为求得一篇报道。然而,这样的过程充满了不确定性和挑战,时常让我感到焦虑和压力山大。 记得有一…

在CentOS 7服务器及Windows 10客户端间建立并配置NFS服务

在CentOS 7服务器及Windows 10客户端间建立并配置NFS服务 引言 网络文件系统(Network File System)&#xff0c;简称NFS&#xff0c;是一种分布式文件系统协议。它允许网络上的客户端机器像访问本地磁盘文件一样&#xff0c;通过网络访问服务器上的文件。在某些特定的业务场景中…

鸿蒙内核源码分析(文件句柄篇) | 你为什么叫句柄

句柄 | handle int open(const char* pathname,int flags); ssize_t read(int fd, void *buf, size_t count); ssize_t write(int fd, const void *buf, size_t count); int close(int fd);只要写过应用程序代码操作过文件不会陌生这几个函数,文件操作的几个关键步骤嘛,跟把大…

202466读书笔记|《一天一首古诗词》——借问梅花何处落,风吹一夜满关山

202466读书笔记|《一天一首古诗词》——借问梅花何处落&#xff0c;风吹一夜满关山 上册下册 《一天一首古诗词》作者李锡琴&#xff0c;蛮早前加入书架的已购买书籍&#xff0c;这次刚好有点时间&#xff0c;利用起来读完。 赏析没有细看&#xff0c;只读了诗词部分&#xff0…

上海AI Lab开源首个可替代GPT-4V的多模态大模型

与开源和闭源模型相比&#xff0c;InternVL 1.5 在 OCR、多模态、数学和多轮对话等 18 个基准测试中的 8 个中取得了最先进的结果。 上海AI Lab 推出的 InternVL 1.5 是一款开源的多模态大语言模型 (MLLM)&#xff0c;旨在弥合开源模型和专有商业模型在多模态理解方面的能力差距…

药物代谢动力学学习笔记

一、基本概念 二、经典房室模型 三、非线性药物代谢动力学 四、非房室模型 五、药代动力学与药效动力学 六、生物等效性评价 七、生物样品分析方法 基本概念 生物样品&#xff1a;生物机体的全血、血浆、血清、粪便、尿液或其他组织的样品 特异性&#xff0c;specificity&…

ntfs文件系统的优势 NTFS文件系统的特性有哪些 ntfs和fat32有什么区别 苹果电脑怎么管理硬盘

对于数码科技宅在新购得磁盘之后&#xff0c;出于某种原因会在新的磁盘安装操作系统。在安装操作系统时&#xff0c;首先要对磁盘进行分区和格式化&#xff0c;而在此过程中&#xff0c;操作者们需要选择文件系统。文件系统也决定了之后操作的流程程度&#xff0c;一般文件系统…

鸿蒙内核源码分析(VFS篇) | 文件系统和谐共处的基础

基本概念 | 官方定义 VFS&#xff08;Virtual File System&#xff09;是文件系统的虚拟层&#xff0c;它不是一个实际的文件系统&#xff0c;而是一个异构文件系统之上的软件粘合层&#xff0c;为用户提供统一的类Unix文件操作接口。由于不同类型的文件系统接口不统一&#x…

Spark Streaming笔记总结(保姆级)

万字长文警告&#xff01;&#xff01;&#xff01; 目录 一、离线计算与流式计算 1.1 离线计算 1.1.1 离线计算的特点 1.1.2 离线计算的应用场景 1.1.3 离线计算代表技术 1.2 流式计算 1.2.1 流式计算的特点 1.2.2 流式计算的应用场景 1.2.3 流式计算的代表技术 二…

Photoshop中选区工具的应用

Photoshop中选区工具的应用 前言Photoshop中选区工具的基本操作创建选区的工具及方法选择、取消、隐藏选区选区的增加、减少选区的应用变换扩大选取与选取相似 Photoshop中采用快速选择工具来创建选区Photoshop中采用色彩范围命令来创建选区Photoshop中采用快速蒙版来创建选区P…

【算法基础实验】排序-最小优先队列MinPQ

优先队列 理论知识 MinPQ&#xff08;最小优先队列&#xff09;是一种常见的数据结构&#xff0c;用于有效管理一组元素&#xff0c;其中最小元素可以快速被检索和删除。这种数据结构广泛应用于各种算法中&#xff0c;包括图算法&#xff08;如 Dijkstra 的最短路径算法和 Pr…

【雅思写作】刘洪波——《最简化雅思写作2.0》笔记——【1. 概述篇】第一章:一些预备知识、第二章:谁对中国考生的写作低分负责

文章目录 第一章 一些预备知识考试类型大作文议论文&#xff08;Argumentation 80%&#xff09;报告&#xff08;Report 20%&#xff09;评分标准写作流程其他格式缩写数字标点符号英式和美式拼写I, My, We, You的使用范文背诵反模板时代机经与预测 第二章 谁对中国考生的写作低…

车载电子电器架构 —— 应用软件开发(中)

车载电子电器架构 —— 应用软件开发(中) 我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 屏蔽力是信息过载时代一个人的特殊竞争力,任何消耗你的人和事,多看一眼都是你的不对。非必要不费力证明…

二、SPI协议

文章目录 总述1.SPI接口2. SPI工作模式3. SPI通信时序4. SPI协议 对比 UART协议&#xff08;上一篇文章刚介绍过uart协议&#xff0c;这里来对比一下&#xff09; 总述 SPI&#xff08;Serial Peripheral Interface&#xff09;是一种高速的、全双工、同步的串行通信总线&…

详解分布式锁

知识点&#xff1a; 单体锁存在的问题&#xff1a; 单体锁&#xff0c;即单体应用中的锁&#xff0c;通过加单体锁&#xff08;synchronized或RentranLock&#xff09;可以保证单个实例并发安全 单体锁是JVM层面的锁&#xff0c;只能保证单个实例上的并发访问安全 如果将单…

基于springboot实现疾病防控综合系统项目【项目源码+论文说明】

基于springboot实现疾病防控综合系统演示 摘要 在如今社会上&#xff0c;关于信息上面的处理&#xff0c;没有任何一个企业或者个人会忽视&#xff0c;如何让信息急速传递&#xff0c;并且归档储存查询&#xff0c;采用之前的纸张记录模式已经不符合当前使用要求了。所以&…

浅谈云计算资源和服务

目录 前言 正文 专有名词及其首字母缩写 轻量级应用服务器 云服务器ECS 专有网络VPC 其他类服务 尾声 &#x1f52d; Hi,I’m Pleasure1234&#x1f331; I’m currently learning Vue.js,SpringBoot,Computer Security and so on.&#x1f46f; I’m studying in University o…

如何在您的WordPress网站上安装和设置W3 Total Cache

本周有一个客户&#xff0c;购买Hostease的虚拟主机&#xff0c;询问我们的在线客服&#xff0c;如何在您的WordPress网站上安装和设置W3 Total Cache&#xff1f;我们为用户提供相关教程&#xff0c;用户很快解决了遇到的问题。在此&#xff0c;我们分享这个操作教程&#xff…

Agent AI智能体的未来:无限可能

文章目录 终结者智能体正反影响自我意识开放心态 终结者 还记得那场人类与天网之间的史诗般的战斗吗&#xff1f;-- 《终结者》系列电影。 《终结者》系列电影是一部标志性的科幻动作系列&#xff0c;以紧张刺激的情节、令人难忘的角色和开创性的视觉效果而闻名。 电影探讨了…