《算法笔记》6.3小节——C++标准模板库(STL)介绍->string的常见用法详解

6.3小节——C++标准模板库介绍->string的常见用法详解

A 字符串处理

题目描述

读入两个字符串,字符串除了数字还可能包括 ‘—’、‘E’、‘e’、’.’,相加之后输出结果,如果是浮点型,要求用科学计数法表示(最多包含10个有效数字)。

输入

输入包含多组测试数据。

每组输入占两行,每行一个字符串,测试数据保证字符串的构成严格按照题目中的描述。

输出

输出两个数字相加的结果,每组输出占一行。

样例输入

34.56
2.45e2

样例输出

2.7956e2

代码提交

#include <cstdio>
#include <iostream>
#include <string>
#include<stdio.h>
using namespace std;

int main(){
	char str1[50],str2[50];
	long long s,s1,s2,ans;
	int i,a1,a2,a,b,c,w,flag;
	while(scanf("%s %s",str1,str2) != EOF){
		//输入str1将其转化为数字
		s1 = s2 = flag = b = c = a1 = 0;
		for(i = 0;str1[i];i++){
			if(str1[i] == '-'){//负号检测
				flag = 1;
			}
			else if(str1[i] == '.'){//浮点小数点检测
				c = 1;
			}
			else if(str1[i] == 'e' || str1[i] == 'E'){//指数符号检测
				sscanf(str1+i+1,"%d",&b);//将指数开始的位置提取
				a1 += b;//指数阶数赋值给a1
				break;
			}
			else{//否则,按照正常的字符串元素处理,将字符转换为数字
				s1 = s1*10 + str1[i] - '0';
				a1 -= c;//如果有小数点,则s1增大一次则a1减小1
			}
		}
		if(flag)	s1 = -s1;//如果有负号,则转化为绝对值的相反数
		//同理输入str2将其转化为数字
		flag = b = c = a2 = 0;
		for(i = 0;str2[i];i++){
			if(str2[i] == '-'){
				flag = 1;
			}
			else if(str2[i] == '.'){
				c = 1;
			}
			else if(str2[i] == 'e' || str2[i] == 'E'){
				sscanf(str2+i+1,"%d",&b);
				a2 += b;
				break;
			}
			else{
				s2 = s2*10 + str2[i]-'0';
				a2 -= c;
			}
		}
		if(flag)	s2 = -s2;
		//对阶
		if(a1 < a2){
			for(;a1<a2;a2--){
				s2 *= 10;
			}
		}
		else if(a1 > a2){
			for(;a1 > a2;a1--){
				s1 *= 10;
			}
		}
		//求和
		a=a1;s=s1+s2;
		if(!s){				//两数之和为0
			printf("0\n");
			continue;
		}
		while(a<0 && s%10 == 0){
			s /= 10;
			a++;//找到a的小数点位置
		}
		if(a >= 0){
			printf("%lld",s);
			for(i = 0;i<a;i++){
				printf("0");
			}
			printf("\n");
			continue;
		}
		flag = 0;
		//判断和数的符号
		if(s<0){
			s = -s;
			flag = 1;
		}
		ans = 1;w = 0;
		//求和数的
		while(ans <= s){
			ans *= 10;
			w++;
		}
		if(ans > 1){
			ans /= 10;
			w--;
		}
		//输出和数
		if(flag){
			printf("-");
		}
		printf("%lld",s/ans);//整数部分
		if(ans > 1){
			printf(".%lld",s%ans);
		}
		printf("e%d\n",a + w);
	}

	return 0;
}


不知道为啥没有通过,显示答案错误

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值