小韦老师@神犇营-my0064-分组游戏
题目:
描述
小码猿和他的同学们要玩一个游戏,在此之前需要将人分为两组。分组规则:每个人随意写一个 n 进制数 x,转换为十进制数,该十进制数为偶数的为一队,该十进制数为奇数的为一队。
输入
输入的数据,在一行内,包括两个整数,依次为 n 和 x,用空格隔开,2 ≤ n ≤ 9,x 为正数,并且最多为 6 位数。
输出
输出为两行,第一行为对应的十进制数。
第二行,若第一行的十进制数为偶数,则输出“Even Team”,否则输出“Odd Team”。
输入样例1
2 1101
输出样例1
13
Odd Team
思路:
整体思路:
先将 n 进制的数 x 用码权积累和转换成对应的十进制数,判断该十进制的
的奇偶性,若为偶数,则输出 Even Team,否则输出 Odd Team。
具体步骤:
1.定义两个变量 n 和 x,并且输入。
2.取得 x 的每一位,因为 x 的位数不多于 6 位,按 x 有 6 位来求是可以的,
因为当位数不足,取得相应的位数为 0。比如是一个三位数,求得的千位,万位,
十万位都为 0,所以不影响最后的结果。
int num1 = x % 10; // x 的个位
int num2 = x / 10 % 10; // x 的十位
int num3 = x / 100 % 10; // x 的百位
int num4 = x / 1000 % 10; // x 的千位
int num5 = x / 10000 % 10; // x 的万位
int num6 = x / 100000; // x 的十万位
3.定义一个 int 型的变量 num,用来存储对应的十进制数,并初始化为 0。
4.根据码权积积累和来计算对应的十进制数:
num += num1 * pow(n, 0);
num += num2 * pow(n, 1);
num += num3 * pow(n, 2);
num += num4 * pow(n, 3);
num += num5 * pow(n, 4);
num += num6 * pow(n, 5);
5.输出 num。
6.若 num 是偶数,则输出 Even Team,否则输出 Odd Team:
cout << ((num % 2 == 0) ? "Even Team" : "Odd Team");
完整代码:
#include <bits/stdc++.h>
using namespace std;
int main() {
int n, x; // n 进制的数 x
cin >> n >> x;
// 取得 x 的每一位,因为 x 的位数不多于 6 位
// 按 x 有 6 位来求是可以的,因为当位数不足,取得相应的位数为 0
// 比如是一个三位数,求得的千位,万位,十万位都为 0,所以不影响最后的结果
int num1 = x % 10; // x 的个位
int num2 = x / 10 % 10; // x 的十位
int num3 = x / 100 % 10; // x 的百位
int num4 = x / 1000 % 10; // x 的千位
int num5 = x / 10000 % 10; // x 的万位
int num6 = x / 100000; // x 的十万位
int num = 0; // 存储对应的十进制数
// 码权积累和
num += num1 * pow(n, 0);
num += num2 * pow(n, 1);
num += num3 * pow(n, 2);
num += num4 * pow(n, 3);
num += num5 * pow(n, 4);
num += num6 * pow(n, 5);
cout << num << endl; // 输出对应的十进制数
// 若 num 是偶数,则输出 Even Team,否则输出 Odd Team
cout << ((num % 2 == 0) ? "Even Team" : "Odd Team");
return 0;
}