洛谷P1055ISBN号码题解--zhengjun

题目描述

每一本正式出版的图书都有一个 I S B N ISBN ISBN号码与之对应, I S B N ISBN ISBN码包括 9 9 9位数字、 1 1 1位识别码和 3 3 3位分隔符,其规定格式如x-xxx-xxxxx-x,其中符号-就是分隔符(键盘上的减号),最后一位是识别码,例如0-670-82162-4就是一个标准的 I S B N ISBN ISBN码。 I S B N ISBN ISBN码的首位数字表示书籍的出版语言,例如 0 0 0代表英语;第一个分隔符-之后的三位数字代表出版社,例如 670 670 670代表维京出版社;第二个分隔符后的五位数字代表该书在该出版社的编号;最后一位为识别码。

识别码的计算方法如下:

首位数字乘以 1 1 1加上次位数字乘以 2 2 2……以此类推,用所得的结果   m o d   11 \bmod 11 mod11,所得的余数即为识别码,如果余数为 10 10 10,则识别码为大写字母 X X X。例如 I S B N ISBN ISBN号码 0 − 670 − 82162 − 4 0-670-82162-4 0670821624中的识别码 4 4 4是这样得到的:对 067082162 067082162 067082162 9 9 9个数字,从左至右,分别乘以 1 , 2 , . . . , 9 1,2,...,9 1,2,...,9再求和,即 0 × 1 + 6 × 2 + … … + 2 × 9 = 158 0×1+6×2+……+2×9=158 0×1+6×2++2×9=158,然后取 158   m o d   11 158 \bmod 11 158mod11的结果 4 4 4作为识别码。

你的任务是编写程序判断输入的 I S B N ISBN ISBN号码中识别码是否正确,如果正确,则仅输出Right;如果错误,则输出你认为是正确的 I S B N ISBN ISBN号码。

输入格式

一个字符序列,表示一本书的 I S B N ISBN ISBN号码(保证输入符合 I S B N ISBN ISBN号码的格式要求)。

输出格式

一行,假如输入的 I S B N ISBN ISBN号码的识别码正确,那么输出Right,否则,按照规定的格式,输出正确的 I S B N ISBN ISBN号码(包括分隔符-)。

输入输出样例
输入 #1 复制
0-670-82162-4
输出 #1 复制
Right
输入 #2 复制
0-670-82162-0
输出 #2 复制
0-670-82162-4
说明/提示

2008 2008 2008普及组第一题

思路

一道特别水的模拟题。

就是-有点不好。

我的方法就是开一个数组,记录 9 9 9个数字的位置(全局直接赋值),然后就算出和,然后直接修改输出。

代码

#include<bits/stdc++.h>
using namespace std;
int a[10]={0,0,2,3,4,6,7,8,9,10};//精髓
string s;
int main(){
	cin>>s;
	int sum=0;
	for(int i=1;i<=9;i++)sum+=(s[a[i]]-'0')*i;//算出总和
	sum%=11;
	if(sum==10&&s[12]=='X')printf("Right");
	else if(sum==s[12]-'0')printf("Right");
	else{
		if(sum!=10)
		s[12]=sum+'0';
		else s[12]='X';
		cout<<s;
	}
	return 0;
}

谢谢–zhengjun

过河卒是一个典型的动态规划问题。首先,我们将整个棋盘看作一个二维数组,数组的每个元素表示到达该位置的路径数目。然后,我们根据题目给出的条件,逐步更新数组中的元素,直到计算出到达目标位置的路径数目。 具体的解题思路如下: 1. 首先,我们可以将马的位置设置为0,表示无法经过该位置。 2. 然后,我们根据马的位置,更新数组中的元素。对于二维数组中的每个位置,我们根据左边和上边的位置来计算到达当前位置的路径数目。具体地,如果左边和上边的位置都可以经过,那么到达当前位置的路径数目就等于左边和上边位置的路径数目之和。如果左边或上边的位置无法经过,那么到达当前位置的路径数目就等于左边或上边位置的路径数目。 3. 最后,我们输出目标位置的路径数目。 下面是洛谷p1002过河卒题解C++代码: ```cpp #include <bits/stdc++.h> using namespace std; int main() { long long a[21][21]; int x1, y1, x2, y2; cin >> x1 >> y1 >> x2 >> y2; // 初始化数组,马的位置设置为0 for(int i=0; i<=20; i++) { for(int k=0; k<=20; k++) { a[i][k] = 1; } } a[x2][y2] = 0; // 根据马的位置更新数组中的元素 if(x2 >= 2 && y2 >= 1) a[x2-2][y2-1] = 0; if(x2 >= 1 && y2 >= 2) a[x2-1][y2-2] = 0; if(x2 <= 18 && y2 >= 1) a[x2+2][y2-1] = 0; if(x2 <= 19 && y2 >= 2) a[x2+1][y2-2] = 0; if(x2 >= 2) a[x2-2][y2+1] = 0; if(x2 >= 1) a[x2-1][y2+2] = 0; if(y2 >= 1) a[x2+2][y2-1] = 0; if(y2 >= 2) a[x2+1][y2-2] = 0; // 动态规划计算路径数目 for(int i=1; i<=20; i++) { for(int k=1; k<=20; k++) { if(a[i][k] != 0) { a[i][k] = a[i-1][k] + a[i][k-1]; } } } // 输出目标位置的路径数目 cout << a[x1][y1] << endl; return 0; } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

A_zjzj

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值