今天这道算法题比较简单,主要考察的思考问题的全面性。这个需要考虑的几种情况。
如果输入的整数字符串是个负数,怎么处理?
如果输入的第一个字符是0,则怎么处理?
如果输入的是非0~9之间的字符怎么处理?
这是目前我能考虑到的问题。
还是使用Matlab实现吧,主要是使用字符的ASCII值来进行这个问题的处理。
clc
clear
closestrInput='-12345';
strLength=size(strInput,2);
%判断输入是否为空白字符串
numberOutput=0;
if strLength==0disp('this input is null !');
elseif strLength==1numberOutput=abs(strInput(strLength))-48;
endif (abs(strInput(1))==45||abs(strInput(1))==48)&&(strLength>1)n=strLength-1;for i=2:strLengthnumberOutput=numberOutput+(abs(strInput(i))-48)*10^(n-i+1);endif abs(strInput(1))==45numberOutput=numberOutput*(-1);elseend
elsen=strLength;for i=1:strLengthnumberOutput=numberOutput+(abs(strInput(i))-48)*10^(n-i);end
end
测试1:
strInput='-12345';
得到的结果为:
numberOutput = -12345
测试2:
strInput='012345';
得到的结果为:
numberOutput = 12345
测试3:
strInput='12345';
得到结果为:
numberOutput = 12345
可以看出来,至少结果是没有错的。至于程序的优化问题需要进一步的思考。