码迷,mamicode.com
首页 > 其他好文 > 详细

UVA 1586 字符串处理

时间:2015-01-05 00:36:34      阅读:219      评论:0      收藏:0      [点我收藏+]

标签:acm   模拟   合并   

背景:做了快40分钟,还是好多细节是调试过来的,看来距离150行以内代码一次通过的能力还很远。

学习:1.变量定义的时候不仅要想到初始化,更要想到初始化的位置,这个变量的作用域如果开大了,和没初始化一样的效果。

代码:

#include<stdio.h>
#include<string.h>
int main(void){
  char str[85];
  int t;
  scanf("%d",&t);
  while(t--){
  	memset(str,'S',sizeof(str));
  	scanf("%s",str);
  	double M,sum=0.0;
  	for(int i=0;i<strlen(str);i++){
  		int n=1;
  	        if(str[i]<='9') continue;
	  	if(str[i]=='C') M=12.01;
		if(str[i]=='H') M=1.008;
		if(str[i]=='O') M=16.00;
		if(str[i]=='N') M=14.01;
		if(str[i+1]<='9'&&str[i+1]>='0'){
		  n=str[i+1]-'0';
		  if(str[i+2]<='9'&&str[i+2]>='0') n=n*10+str[i+2]-'0';
	    }
		sum+=M*n;	
  	}
  	printf("%.3lf\n",sum);
  }
  return 0;
}


UVA 1586 字符串处理

标签:acm   模拟   合并   

原文地址:http://blog.csdn.net/jibancanyang/article/details/42407017

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!