Codeup-100000575 -《算法笔记》

前言:

21考研,正在啃《算法笔记》,不论能否进复试记录一下准备路上写下的垃圾代码。

解答:

#include<cstdio>
#define max 20
int Cnum(char num[],int len){
	int rnum=0,count=1;
			for(int i=len-2;i>=0;i--)       //字符数组最后会多个/0,导致末尾多一个0,故-2			                                //故此处-2消除这一问题的影响
				if(num[i]>='0'&&num[i]<='9')
				{
					rnum=rnum+count*((int)num[i]-int('0'));
					count=count*10;
				}
    if(num[0]=='-')
		rnum=-rnum;
	return rnum;
}
int main(){
	char num1[max],num2[max];
	int rnum1,rnum2,count=0; //rnum1和rnum2记录真值
	int len1=0,len2=0;       //记录各数组长度
	int init=0;              //用于初始化字符数组
			while(init<max){
			num1[init]='#';
			num2[init]='#';
			init++;
		}
	while(scanf("%s %s",num1,num2)!=EOF){
		while(num1[count]!='#')
		{
			len1++;
			count++;
		}
		count=0;
		while(num2[count]!='#')
		{
			len2++;
			count++;
		}
		rnum1=Cnum(num1,len1);
		rnum2=Cnum(num2,len2);
		printf("%d",rnum1+rnum2);
		printf("\n");
		init=0;               //为应付codeup的多点测试,最后重新初始化字符数组
		while(init<max){
		num1[init]='#';
		num2[init]='#';
		init++;
		}
	}
	return 0;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值