题目
源地址:
http://poj.org/problem?id=2498
理解
英文题= =。按照{9,3,7}的顺序,从后往前乘,最后的乘积相加可以被十整除。但是有一个数字看不清了,要求计算出那个数字,并且输出整个数。
代码
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cmath>
#include <ctime>
#include <iostream>
#include <algorithm>
#include <string>
#include <vector>
#include <deque>
#include <list>
#include <set>
#include <map>
#include <stack>
#include <queue>
#include <numeric>
#include <iomanip>
#include <bitset>
#include <sstream>
#include <fstream>
#define debug puts("-----")
#define pi (acos(-1.0))
#define eps (1e-8)
#define inf (1<<30)
using namespace std;
int main(int argc, char const *argv[])
{
int t, testCase, i, v[3] = {9, 3, 7};
char num[10];
scanf("%d", &testCase);
for (t = 1; t <= testCase; t ++)
{
scanf("%s", num);
int sum = 0, p = 0, w, k;
for (i = strlen(num) - 1; i >= 0; i --)
{
if (num[i] == '?')
{
w = v[p];
k = i;
}
else sum += (num[i] - '0') * v[p];
p ++;
if (p == 3) p = 0;
}
for (i = 0; i < 10; i ++)
if ((sum + i * w) % 10 == 0)
{
num[k] = '0' + i;
printf("Scenario #%d:\n%s\n\n", t, num);
break;
}
}
return 0;
}
更新日志
- 2014年08月16日 已AC。