【未经作者同意,不许转载!!!!!!未经作者同意,不许转载!!!!!!未经作者同意,不许转载!!!!!!】
【讨论加我QQ:1721324995 讨论加我QQ:1721324995 讨论加我QQ:1721324995 非诚勿扰!非诚勿扰!非诚勿扰!】
思路:
话说乍一看,我屮艸芔茻,蒟蒻啊!然后再一看~啊~原来还是有难度的。
一开始想复杂了,想着一个人最多经过多少天,然后做减法。
应该是:最先判断是否在2月29日出生,如果是,则输出-1。每个人最少会过365*18天生日。然后判断出生年,如果是闰年,且日期在2月29日之前,则+1,多过一天;再判断18岁生日那年,如果是闰年,且月份大于3,则+1,多过一天。最后循环从1岁到17岁的年份,如果是闰年,则+1,多过一天。
先看一份错误代码(WA50%):
var
st:string;y,m,d,n,sum,i,j:longint;
function leap(x:longint):boolean;
begin
if ((x mod 4=0)and(x mod 100<>0))or(x mod 400=0) then exit(true) else exit(false);
end;
begin
readln(n);
for i:=1 to n do
begin
readln(st);
val(copy(st,1,4),y);
val(copy(st,6,2),m);
val(copy(st,8,2),d);
if (m=2) and (d=29) then begin
writeln(-1);continue;
end;
sum:=365*18;
if leap(y) and ((m<2)or(m=2)and(d<29)) then inc(sum);
if leap(y+18) and (m>2) then inc(sum);
for j:=y+1 to y+17 do
if leap(j) then inc(sum);
writeln(sum);
end;
end.
var
st:string;y,m,d,n,sum,i,j:longint;
function leap(x:longint):boolean;
begin
if ((x mod 4=0)and(x mod 100<>0))or(x mod 400=0) then exit(true) else exit(false);
end;
begin
readln(n);
for i:=1 to n do
begin
readln(st);
val(copy(st,1,4),y);
val(copy(st,6,2),m);
val(copy(st,9,2),d);
if (m=2) and (d=29) then begin
writeln(-1);continue;
end;
sum:=365*18;
if leap(y) and ((m<2)or(m=2)and(d<29)) then inc(sum);
if leap(y+18) and (m>2) then inc(sum);
for j:=y+1 to y+17 do
if leap(j) then inc(sum);
writeln(sum);
end;
end.
我保证你在5分钟内找不到不同。我找这出错找了近半个小时。
答案是在(16,17)的“8”和“9”。就因为这相差1的两个数,我“损失”了50分。如果这是考试,那该多可怕!
难怪说“细节决定成败”,Let me be more careful!
【未经作者同意,不许转载!!!!!!未经作者同意,不许转载!!!!!!未经作者同意,不许转载!!!!!!】
【讨论加我QQ:1721324995 讨论加我QQ:1721324995 讨论加我QQ:1721324995 非诚勿扰!非诚勿扰!非诚勿扰!】