# [NOIP2008 普及组] ISBN 号码
## 题目描述
每一本正式出版的图书都有一个 ISBN 号码与之对应,ISBN 码包括 $9$ 位数字、$1$ 位识别码和 $3$ 位分隔符,其规定格式如 `x-xxx-xxxxx-x`,其中符号 `-` 就是分隔符(键盘上的减号),最后一位是识别码,例如 `0-670-82162-4`就是一个标准的 ISBN 码。ISBN 码的首位数字表示书籍的出版语言,例如 $0$ 代表英语;第一个分隔符 `-` 之后的三位数字代表出版社,例如 $670$ 代表维京出版社;第二个分隔符后的五位数字代表该书在该出版社的编号;最后一位为识别码。
识别码的计算方法如下:
首位数字乘以 $1$ 加上次位数字乘以 $2$ ……以此类推,用所得的结果 $ \bmod 11$,所得的余数即为识别码,如果余数为 $10$,则识别码为大写字母 $X$。例如 ISBN 号码 `0-670-82162-4` 中的识别码 $4$ 是这样得到的:对 `067082162` 这 $9$ 个数字,从左至右,分别乘以 $1,2,\dots,9$ 再求和,即 $0\times 1+6\times 2+……+2\times 9=158$,然后取 $158 \bmod 11$ 的结果 $4$ 作为识别码。
你的任务是编写程序判断输入的 ISBN 号码中识别码是否正确,如果正确,则仅输出 `Right`;如果错误,则输出你认为是正确的 ISBN 号码。
## 输入格式
一个字符序列,表示一本书的 ISBN 号码(保证输入符合 ISBN 号码的格式要求)。
## 输出格式
一行,假如输入的 ISBN 号码的识别码正确,那么输出 `Right`,否则,按照规定的格式,输出正确的 ISBN 号码(包括分隔符 `-`)。
## 样例 #1
### 样例输入 #1
```
0-670-82162-4
```
### 样例输出 #1
```
Right
```
## 样例 #2
### 样例输入 #2
```
0-670-82162-0
```
### 样例输出 #2
```
0-670-82162-4
```
## 提示
2008 普及组第一题
代码如下,详解在后面
s = input()
ISBN = s.replace("-", "")
en = ISBN[-1]
total = 0
s_en = ISBN[:-1]
ISBN_s = s_en[::-1]
for i in range(9):
total += int(ISBN_s[i]) * (9 - i)
n = total % 11
if (n == 10 and en == "X") or (n != 10 and str(n) == en):
print("Right")
else:
if n == 10:
print(f"{s[:-1]}X")
else:
print(f"{s[:-1]}{n}")
"""
s = input() # 获取用户输入的 ISBN 号(可以包含 '-')
ISBN = s.replace("-", "") # 去掉输入中的连字符,得到纯数字的 ISBN
en = ISBN[-1] # 提取校验位,即最后一位字符
total = 0 # 初始化累加总和为 0
s_en = ISBN[:-1] # 获取除校验位外的前 9 位数字
ISBN_s = s_en[::-1] # 将前 9 位数字反转,便于计算权重
# 计算前 9 位数字的加权和
for i in range(9):
total += int(ISBN_s[i]) * (9 - i) # 每位数字乘以其对应的权重(9 到 1)
n = total % 11 # 计算模 11 的结果,得到校验位的值
# 检查计算出的校验位与输入的校验位是否匹配
if (n == 10 and en == "X") or (n != 10 and str(n) == en):
print("Right") # 如果匹配,输出 "Right"
else:
# 如果不匹配,根据计算的校验位输出格式化字符串
if n == 10:
print(f"{s[:-1]}X") # 如果计算出的校验位为 10,输出 "X"
else:
print(f"{s[:-1]}{n}") # 否则输出计算出的校验位
"""