2017-05-19
题目大意:
给定两个字符串S1、S2,长度都在6以内。字符’A’对应数字1, 字符’B’对应数字2, 以此类推。对于给定字符串,计算该字符串的所有字母对于数字的乘积。 比如字符串”USACO” = 21 * 19 * 1 * 3 * 15 = 17955. 计算S1和S2对应的值,并且对47取模。如果取模后,计算得到两个数字相等,则输出”GO”, 否则输出 “STAY”。
题解:
usaco的第一题,根据题目的描述翻译成代码即可。
代码:
/*
ID: zachery1
PROG: ride
LANG: C++
*/
#include <iostream>
#include <fstream>
#include <string>
#define cin fin
#define cout fout
using namespace std;
ifstream fin("ride.in");
ofstream fout("ride.out");
string group, comet;
long long g, c;
int main() {
ios::sync_with_stdio(false);
g = c = 1;
cin >> group >> comet;
for (int i = 0; i < group.length(); i++) {
g *= (group[i] - 'A' + 1);
g %= 47;
}
for (int i = 0; i < comet.length(); i++) {
c *= (comet[i] - 'A' + 1);
c %= 47;
}
if (g == c) cout << "GO" << endl;
else cout << "STAY" << endl;
return 0;
}