解法不唯一,但是还是set好理解而且用着爽,代码注释应该够详细了
#include<stdio.h> #include<string.h> #include<math.h> #include<time.h> #include<iostream> #include<ctype.h> #include<map> #include<set> #include<string> #include<vector> #include<algorithm> #include<stdlib.h> #include<queue> #include<stack> using namespace std; set<string>s1; set<string>s2; set<string>::iterator tt; char ss[205]; char str[505][110]; int cc(char cs)//只检查字母数字,也就是存化学式,碰见+或者=就跳过去 { if(isdigit(cs)) return 1; if(isalpha(cs)) return 1; return 0; } int main() { int t,i,j,n,m,fla,k; while(~scanf("%d",&n)) { s1.clear(); s2.clear(); for(i=0;i<n;i++) scanf("%s",str[i]); scanf("%d",&m); for(i=0;i<m;i++) { scanf("%s",ss); s1.insert(ss); } for(i=0;i<n;i++) { fla=0;//,每一次也就是每个化学方程式都是从左开始,判断是=号左侧还是右侧的,右侧生成物也得存入反应物里,也就是s1集合里边,左侧的话直接检测给的能用的反应物以及生成物集合s1里有没有就行了 for(j=0;j<strlen(str[i]);j++) { if(fla)//右侧生成物 { k=0; memset(ss,'