华为机试—两个任意长度的正数相减

问题描述:

两个任意长度的正数相减,这两个正数可以带小数点,也可以是整数,请输出结果。输入的字符串中,不会出现除了数字与小数点以外的其它字符,不会出现多个小数点以及小数点在第一个字符的位置等非法情况,所以考生的程序中无须考虑输入的数值字符串非法的情况。

详细要求以及约束:

1.输入均为正数,但输出可能为负数;

2.输入输出均为字符串形式;

3.如果输出是正数则不需要带符号,如果为负数,则输出的结果字符串需要带负号

例如:2.2-1.1直接输出为“1.1”,1.1-2.2 则需要输出为“-1.1”

4.输出的结果字符串需要过滤掉整数位前以及小数位后无效的0,小数位为全0的,直接输出整数位

例如相减结果为11.345,此数值前后均不可以带0,“011.345”或者“0011.34500”等等前后带无效0的均视为错误输出。例如1.1-1.1结果为0.0,则直接输出0。

要求实现函数:

void Decrease(char *input1, char*input2, char *output)

【输入】char *input1 被减数

char *input2 减数

【输出】char *output 减法结果

【返回】无

示例

输入:char *input1="2.2"

char *input2="1.1"

输出:char*output="1.1"

输入:char*input1="1.1"

char *input2="2.2"

输出:char*output="-1.1"

#include <iostream>
using namespace std;

void Decrease(char *input1, char*input2, char *output)
{
	int i;
	int n1=0;
	int n2=0;
	int m1=0;
	int m2=0;
	for(i=0;input1[i]!='.';i++)
	{
		if(input1[i]=='\0')
		{
			m1=-1;
			break;
		}
		++n1;
	}
	if(m1==-1)
		m1=0;
	else
	{
		for(++i;input1[i]!='\0';i++)
		{
			++m1;
		}
	}

	for(i=0;input2[i]!='.';i++)
	{
		if(input2[i]=='\0')
		{
			m2=-1;
			break;
		}
		++n2;
	}

	if(m2==-1)
		m2=0;
	else
	{
		for(++i;input2[i]!='\0';i++)
		{
			++m2;
		}
	}

	cout<<"n1="<<n1<<" "<<"n2="<<n2<<endl;
	cout<<"m1="<<m1<<" "<<"m2="<<m2<<endl;

	int m3=(m1>m2?m1:m2);
	int n3=(n1>n2?n1:n2);
	int len=n3+m3;
	char *s1=new char[len];
	char *s2=new char[len];
	char *s3=new char[len+1];
	for(i=0;i<n3;i++)
	{
		if(n3-i>n1)
			s1[i]='0';
		else
			s1[i]=input1[n1+i-n3];
		if(n3-i>n2)
			s2[i]='0';
		else
			s2[i]=input2[n2+i-n3];
	}

	for(i=n3;i<m3+n3;i++)
	{
		if(i-n3<m1)
			s1[i]=input1[n1+1+i-n3];
		else
			s1[i]='0';
		if(i-n3<m2)
			s2[i]=input2[n2+1+i-n3];
		else
			s2[i]='0';
	}

	s1[i]='\0';
	s2[i]='\0';

	cout<<s1<<endl;
	cout<<s2<<endl;

	int k=0;

	for(i=0;i<len;i++)
	{
		if(s1[i]>s2[i])
			break;
		else if(s1[i]<s2[i])
		{
			k=-1;
			break;
		}
	}

	int d=0;

	if(k==-1)
	{
		for(i=0;i<len;i++)
		{
			swap(s1[i],s2[i]);
		}
		output[d++]='-';
	}

	cout<<s1<<endl;
	cout<<s2<<endl;

	k=0;
	for(i=len-1;i>-1;i--)
	{
		if((k+s1[i]-s2[i])>=0)
		{
			s3[i]='0'+k+s1[i]-s2[i];
			k=0;
		}
		else
		{
			s3[i]='0'+10+k+s1[i]-s2[i];
			k=-1;
		}
		cout<<"s3[]	"<<i<<"	"<<s3[i]<<endl;
	}

	s3[len]='\0';
	cout<<s3<<endl;

	int start=0;
	for(i=0;i<n3;i++)
	{
		if(start==0 && s3[i]=='0')
			continue;
		start=1;

		output[d++]=s3[i];
	}
	if(start==0)
		output[d++]='0';

	start=0;

	for(i=len-1;i>n3-1;i--)
	{
		if(start==0&&s3[i]=='0')
			continue;
		start=1;
		break;
	}

	int a1=i;

	if(start==0)
	{
		output[d]='\0';
	}
	else
	{
		output[d++]='.';
		for(i=n3;i<a1+1;i++)
			output[d++]=s3[i];
		output[d]='\0';
	}

}

int main()
{
	char *input1="11.1" ;
	char *input2="112.2";
	char *output=new char[100];
	Decrease(input1, input2, output);
	cout<<output<<endl;

	return 0;
}

时间: 2024-10-13 16:26:01

华为机试—两个任意长度的正数相减的相关文章

[华为机试真题]69.姓名的夫妻相

题目 在中国,形容夫妻恩爱的词汇中,大家用的比较多的就是"夫妻相".所谓"夫妻相",就是两个人看上去比较般配,长相.身材等某些方面有一定的相似度. 本题则另辟蹊径,从人的姓名维度,以字母重复个数来寻找最具"夫妻相"的人. 题目中预先给定一组女士的姓名拼音.输入男士的姓名拼音(拼音中间可以有空格,字母全部小写),依预先给定姓名拼音的先后遍历所有姓名,输出字母重复数最多的女士姓名. 规则1:如果字母重复数最多的女士有多位相同,则以最先匹配的女士做为最

[华为机试真题][2014]64.实现两个合法时间相加

题目 描述: 给定两个合法的时间(格式固定:hh:mm:ss,时间合法,不用考虑其它情况),输入两个时间相加后的结果:注意,相加后的结果也必需是一个合法的时间: 附合法时间定义:小时在[00-23]之间,分钟和秒分别是在[00-59]之间: 运行时间限制: 无限制 内存限制: 无限制 输入: 时分秒格式的时间字符串,如00:00:00 输出: 时分秒格式的时间字符串,如00:00:00 样例输入: 00:00:00 00:00:01 样例输出: 00:00:01 答案提示: 建议将时间转换为秒数

2014华为机试西安地区B组试题

2014华为机试西安地区B组试题 题目一.亮着点灯的盏数 一条长廊里依次装有n(1≤n≤65535)盏电灯,从头到尾编号1.2.3.-n-1.n.每盏电灯由一个拉线开关控制.开始,电灯全部关着. 有n个学生从长廊穿过.第一个学生把号码凡是1的倍数的电灯的开关拉一下:接着第二个学生把号码凡是2的倍数的电灯的开关拉一下:接着第三个学生把号码凡是3的倍数的电灯的开关拉一下:如此继续下去,最后第n个学生把号码凡是n的倍数的电灯的开关拉一下.n个学生按此规定走完后,长廊里电灯有几盏亮着. 注:电灯数和学生

华为机试(2)

简单题   题目描述  输入一个字符串,统计其出现频率最高的字符,并输出.若存在两个字符出现频率相同,则输出字典序较小的那一个   输入描述  :一个字符串,保证没有空格,以回车符结束,字符串长度<=20   输出描述  :一个字符   输入样例 :aabbaabb  输出样例  :a  解题思路:做一个频率数组来统计所有字符的出现频率,机试时候不会有汉字输入,因此只考虑输入是ASCII编码的情况. #include<string> #include<iostream> us

华为机试(A)

二叉树遍历        答题时间: 00 小时 03 分 11 秒 描述:  二叉树的前序.中序.后序遍历的定义: 前序遍历:对任一子树,先访问跟,然后遍历其左子树,最后遍历其右子树: 中序遍历:对任一子树,先遍历其左子树,然后访问根,最后遍历其右子树: 后序遍历:对任一子树,先遍历其左子树,然后遍历其右子树,最后访问根. 给定一棵二叉树的前序遍历和中序遍历,求其后序遍历(提示:给定前序遍历与中序遍历能够唯一确定后序遍历). 题目类别:  树  难度:  中级  运行时间限制: 无限制 内存限

2014年6月6日--华为机试

准备了还有一段时间了,结果还是悲剧了,主要准备的是算法,结果华为机试更看重字符串的操作,这一块正好是自己的弱项,哎.不过还有时间,这几个月多刷刷题,多锻炼锻炼,加油吧. 机试一共考了三道题,两道简单点的,一道难题,难题考得是状态机,不知道是什么东西╮(╯▽╰)╭,简单的两题做的也不好,回来在重新做一下.   1.倒置英文句子中单词的字母顺序. hello, I am good.  ->  olleh, I ma doog. 这题其实不难,当时脑子有点纠结符号,所以没做出来,还有一点客观原因,平时

2014深圳华为机试剖析

题一: (1)给出一个整数(负数使用其绝对值),输出这个整数中的两种递减数(1.最大递减数:2.递减数中各位数之和最大的数)之和. 递减数:一个数字的递减数是指相邻的数位从大到小排列的数字,不包含相邻的数位大小相同的情况.最大递减数:所输入整数的所有递减数中值最大的一个. 如: 75345323,递减数有:75,753,53,53,532,32.那么最大的递减数为753. 各位数字之和最大的递减数: 如75345323中的各递减数:75各位数之和=12(7+5=12),753各位数之和=15(7

华为机试-公共字串计算

题目描述题目标题:计算两个字符串的最大公共字串的长度,字符不区分大小写详细描述:接口说明原型:int getCommonStrLength(char * pFirstStr, char * pSecondStr);输入参数: char * pFirstStr //第一个字符串 char * pSecondStr//第二个字符串 输入描述:输入两个字符串 输出描述:输出一个整数 输入例子:asdfas werasdfaswer 输出例子:6 效率低的Java程序实现: import java.ut

华为机试(8)

高级题样题:地铁换乘  描述:已知2条地铁线路,其中A为环线,B为东西向线路,线路都是双向的.经过的站点名分别如下,两条线交叉的换乘点用T1.T2表示.编写程序,任意输入两个站点名称,输出乘坐地铁最少需要经过的车站数量(含输入的起点和终点,换乘站点只计算一次). 地铁线A(环线)经过车站:A1 A2 A3 A4 A5 A6 A7 A8 A9 T1 A10 A11 A12 A13 T2 A14 A15 A16 A17 A18 地铁线B(直线)经过车站:B1 B2 B3 B4 B5 T1 B6 B7