C++区分化学中某些简单的常见同分异构体

2023-10-21 11:30

本文主要是介绍C++区分化学中某些简单的常见同分异构体,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目描述

在这里插入图片描述
如上图,,这个烷烃基有6个原子和5个化学键,6个原子分别标号1~6,然后用一对数字 a,b 表示原子a和原子b间有一个化学键。这样通过5行a,b可以描述一个烷烃基。(原子之间的编号顺序任意)
你的任务是甄别烷烃基的类别。

Input

输入第一行为数据的组数T(1≤T≤200000)。每组数据有5行,每行是两个整数a, b(1≤a,b≤6,a ≤b)数据保证,输入的烷烃基是以上5种之一

Output

每组数据,输出一行,代表烷烃基的英文名

Example

Input2
1 2
2 3
3 4
4 5
5 6
1 4
2 3
3 4
4 5
5 6Outputn-hexane
3-methylpentane

解题思路

想要区分不同的同分异构体,就要找到每一个异构体的独特之处。
由于弱鸡是弱鸡,只能采用最简单原始的方法解决问题。仔细观察上图,首先将其看成五个图(但凡了解图的人应该都能做出如此判断),然后可发现几个同分异构体之间的不同点:

  1. 五个图之间的点的度数不同。比如第一个图只有度为1和2的点,而其他的图均有度大于2的点。这便是针对这道题的一个不同点。
  2. 2-methylpentane和3-methylpentane两个图虽然度完全相同,但度为3的点所在位置不同,前者度为3的点所连接的点的度为1和2,而后者度为3的点所连接的两个点的度均为2。

到这里,本题已经解决了一半,剩下的便是将上述思路“翻译”成C++语言即可。为了方便“翻译”,可以先选择保存值所需要的变量和结构。
首先是输入值的处理,同时为了方便图的描述,选择用大小为5的结构体数组pic[5]来保存“化学键”。结构体中只包含两个int型的变量;除此之外,由于需要计算每个点的度数,因此还需要用一个int型数组deg[7](7是根据输入值决定的)来表示;同时,为了区别某些图,还要用数组sum[5]来表示每一种度数的顶点个数。

代码

ok,接下来可以直接上代码(希望不要被嫌弃!!!!!)

#include<iostream>
using namespace std;
struct node//表示化学键
{int a;int b;
};
int main()
{node pic[5];//保存输入的5个化学键int deg[7];//用来保存每一个点的度 int sum[5];//用来保存每一种度数的顶点个数 int third;//用来专门记录度为3的顶点(这里可先忽略)int n;cin>>n;for(int i=0;i<n;i++){for(int j=0;j<7;j++)deg[j]=0;for(int j=0;j<5;j++){cin>>pic[j].a>>pic[j].b;deg[pic[j].a]++;//将对应的点的度+1deg[pic[j].b]++;}for(int j=0;j<5;j++)sum[j]=0; for(int j=1;j<7;j++){sum[deg[j]]++; if(deg[j]==3)  third=j;//找到度为3的顶点 } if(sum[2]==4)cout<<"n-hexane"<<endl;if(sum[4]==1)cout<<"2,2-dimethylbutane"<<endl;if(sum[3]==2)cout<<"2,3-dimethylbutane"<<endl;if(sum[2]==2)//为了区分剩下的两个同分异构体,需要利用度为3的店和这个点连接的点的度数之和{int bb=0;//用来记录度为3的点连接的点的度数之和for(int j=0;j<5;j++){if(pic[j].a==third)bb+=deg[pic[j].b];else if(pic[j].b==third)  bb+=deg[pic[j].a];}if(bb==5)cout<<"3-methylpentane"<<endl;if(bb==4)cout<<"2-methylpentane"<<endl;		        }}return 0;
} 

反省与感想

解题方法并不好,没有做到“泛型程序设计”的目标,只是针对特定的某些同分异构体有帮助(由于实在太弱,想不到更好的方法)。更没有什么算法和程序思维的使用。各位见谅!

写在最后

作为一名程序员小白,想努力写好代码,但脑子过于迟钝,唉。。。。。没办法
不过既然选择了要学这门专业,就算再苦再难再累,也得夜以继日的敲代码(老师逼得狠,身边的大佬逼得更狠)
希望所有程序员,不管是小白还是大佬,都可以越肝越勇,少掉几根头发!!!

这篇关于C++区分化学中某些简单的常见同分异构体的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/254095

相关文章

C#如何调用C++库

《C#如何调用C++库》:本文主要介绍C#如何调用C++库方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录方法一:使用P/Invoke1. 导出C++函数2. 定义P/Invoke签名3. 调用C++函数方法二:使用C++/CLI作为桥接1. 创建C++/CL

Java Spring 中 @PostConstruct 注解使用原理及常见场景

《JavaSpring中@PostConstruct注解使用原理及常见场景》在JavaSpring中,@PostConstruct注解是一个非常实用的功能,它允许开发者在Spring容器完全初... 目录一、@PostConstruct 注解概述二、@PostConstruct 注解的基本使用2.1 基本代

SQL中redo log 刷⼊磁盘的常见方法

《SQL中redolog刷⼊磁盘的常见方法》本文主要介绍了SQL中redolog刷⼊磁盘的常见方法,将redolog刷入磁盘的方法确保了数据的持久性和一致性,下面就来具体介绍一下,感兴趣的可以了解... 目录Redo Log 刷入磁盘的方法Redo Log 刷入磁盘的过程代码示例(伪代码)在数据库系统中,r

C++如何通过Qt反射机制实现数据类序列化

《C++如何通过Qt反射机制实现数据类序列化》在C++工程中经常需要使用数据类,并对数据类进行存储、打印、调试等操作,所以本文就来聊聊C++如何通过Qt反射机制实现数据类序列化吧... 目录设计预期设计思路代码实现使用方法在 C++ 工程中经常需要使用数据类,并对数据类进行存储、打印、调试等操作。由于数据类

SQL BETWEEN 的常见用法小结

《SQLBETWEEN的常见用法小结》BETWEEN操作符是SQL中非常有用的工具,它允许你快速选取某个范围内的值,本文给大家介绍SQLBETWEEN的常见用法,感兴趣的朋友一起看看吧... 在SQL中,BETWEEN是一个操作符,用于选取介于两个值之间的数据。它包含这两个边界值。BETWEEN操作符常用

Linux下如何使用C++获取硬件信息

《Linux下如何使用C++获取硬件信息》这篇文章主要为大家详细介绍了如何使用C++实现获取CPU,主板,磁盘,BIOS信息等硬件信息,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录方法获取CPU信息:读取"/proc/cpuinfo"文件获取磁盘信息:读取"/proc/diskstats"文

python中各种常见文件的读写操作与类型转换详细指南

《python中各种常见文件的读写操作与类型转换详细指南》这篇文章主要为大家详细介绍了python中各种常见文件(txt,xls,csv,sql,二进制文件)的读写操作与类型转换,感兴趣的小伙伴可以跟... 目录1.文件txt读写标准用法1.1写入文件1.2读取文件2. 二进制文件读取3. 大文件读取3.1

C++使用printf语句实现进制转换的示例代码

《C++使用printf语句实现进制转换的示例代码》在C语言中,printf函数可以直接实现部分进制转换功能,通过格式说明符(formatspecifier)快速输出不同进制的数值,下面给大家分享C+... 目录一、printf 原生支持的进制转换1. 十进制、八进制、十六进制转换2. 显示进制前缀3. 指

C++中初始化二维数组的几种常见方法

《C++中初始化二维数组的几种常见方法》本文详细介绍了在C++中初始化二维数组的不同方式,包括静态初始化、循环、全部为零、部分初始化、std::array和std::vector,以及std::vec... 目录1. 静态初始化2. 使用循环初始化3. 全部初始化为零4. 部分初始化5. 使用 std::a

前端下载文件时如何后端返回的文件流一些常见方法

《前端下载文件时如何后端返回的文件流一些常见方法》:本文主要介绍前端下载文件时如何后端返回的文件流一些常见方法,包括使用Blob和URL.createObjectURL创建下载链接,以及处理带有C... 目录1. 使用 Blob 和 URL.createObjectURL 创建下载链接例子:使用 Blob