编写一个名为day_diff的函数,它接受四个标量正整数输入,month1,day1,month2,day2。这些代表了2015年出生的两个孩子的生日。该函数返回一个正整数标量,该标量等于两个孩子的年龄之间的差异。确保检查输入值是否为正确的类型,并且它们代表有效日期。如果它们是错误的,则返回-1。对函数的示例调用将是:
dd = day_diff(1,30,2,1);
这将使dd等于2.您不能使用内置函数datenum
或datetime
。
function dd = day_diff(month1, day1, month2, day2)
if (month1 && month2 > 0) || (month1 && month2 <= 12)
if month1 == 1 && month2 == 1
if day1 == day2
total1 = day1;
total2 = day2;
elseif day1 ~= day2
total1 = max(day1,day2);
total2 = min(day1,day2);
end
elseif month1 == 1 && month2 == 2
total1 = day1;
total2 = day2 + 31;
elseif (month1 == 2 && day1 <= 28) && month2 == 1
total1 = day1 + 31;
total2 = day2;
elseif month1 == 1 && month2 == 12
total1 = day1;
total2 = day2 + 334;
elseif month1 == 2 && month2 == 3
total1 = day1 + 31;
total2 = day2 + 59;
elseif month1 == 7 && month2 == 9
total1 = day1 + 181;
total2 = day2 + 243;
elseif month1 == 1 && month2 == 4
total1 = day1;
total2 = day2 + 90;
else
dd = -1;
return
end
end
if (day1<1 || day1>31) || (month1<1 || month1>12)
dd = -1;
return
elseif day2<1 || day2>31 || (month2<1 || month2>12)
dd = -1;
return
else
dd = (max(total1,total2)) - (min(total1,total2));
end
我的函数表现良好,除非我有一个向量作为输入参数(如(12,3,[3,4],5)。我尝试使用~isscalar
但它似乎没有工作方式我做到了。
谢谢!
答案 0 :(得分:1)
我会做类似的事情:
function dd = day_diff(varargin)
if nargin~= 4 || any(~cellfun(@isscalar,varargin))
dd = -1; return;
end
month1 = varargin{1};
day1 = varargin{2};
month2 = varargin{3};
day2 = varargin{4};
... rest of your code
答案 1 :(得分:0)
要检查输入的任何是否不是数组,您可以执行以下操作:
if any([length(month1)~=1, length(month2)~=1, length(day1)~=1, length(day2)~=1;])
dd=-1;
return;
end
答案 2 :(得分:-2)
解决方案不正确。例如,如果你将使用(8,29,825)你必须有4天,但在你的程序中你将有-1。所有的程序都写错了很多