我有这个任务,我要求用户输入 11 位代码(字符串)。
1) 例如,假设用户输入代码为 37605030299。
2)然后我需要检查最后一个数字是否匹配。这是您获得最后一个数字的方式:nr11 = (nr1*1 + nr2*2 + nr3*3 + nr4*4 + nr5*5 + nr6*6 + nr7*7 + nr8*8 + nr9*9 + nr10* 1) 模式 11
3)这是我写的:
var C, nr1, nr2, nr3, nr4, nr5, nr6, nr7, nr8, nr9, nr10, nr11: string;
begin
nr1:=(copy(C, 1, 1));
nr2:=(copy(C, 2, 1));
nr3:=(copy(C, 3, 1));
nr4:=(copy(C, 4, 1));
nr5:=(copy(C, 5, 1));
nr6:=(copy(C, 6, 1));
nr7:=(copy(C, 7, 1));
nr8:=(copy(C, 8, 1));
nr9:=(copy(C, 9, 1));
nr10:=(copy(C, 10, 1));
nr11:=(copy(C, 11, 1));
writeln('Enter the code which contains 11 digits:');
readln(C);
if nr11 = (nr1*1 + nr2*2 + nr3*3 + nr4*4 + nr5*5 + nr6*6 + nr7*7 + nr8*8 + nr9*9 + nr10*1) mod 11 then
begin
writeln('The code is correct!');
end
else
if nr11 <> (nr1*1 + nr2*2 + nr3*3 + nr4*4 + nr5*5 + nr6*6 + nr7*7 + nr8*8 + nr9*9 + nr10*1) mod 11
begin
writeln('The code is incorrect!');
end;
readln();
end.
这不起作用,因为我知道你不能像我一样在方程式中使用字符串,但它会起作用吗?我只是在学习 Pascal,如果这看起来太愚蠢了,对不起。
此 UI 代码应该是正确的。检查:
1*3 + 2*7 + 3*6 + 4*0 + 5*5 + 6*0 + 7*3 + 8*0 + 9*2 + 1*9 = 108
108/11 ~ 9,8
9*11 = 99
108-99 = 9(答案是9,所以最后一位必须是9,最后一位是9表示密码正确)
如果您不明白我试图做什么,那么我在 python 中找到了一个应该是正确的示例:
def checkIDCode(code):
if len(code) != 11 or not code.isdigit():
return False
c = map(int,code)
w1 = [1,2,3,4,5,6,7,8,9,1]
w2 = [3,4,5,6,7,8,9,1,2,3]
s1 = sum(map(lambda x,y: x*y, c[:-1], w1))%11
s2 = (sum(map(lambda x,y: x*y, c[:-1], w2))%11)%10
return s1 == c[-1] or s1 == 10 and s2 == c[-1]