P8723 [蓝桥杯 2020 省 AB3] 乘法表

题目描述:

九九乘法表是学习乘法时必须要掌握的。在不同进制数下,需要不同的乘法表。

例如, 四进制下的乘法表如下所示:

复制代码
1*1=1
2*1=2 2*2=10
3*1=3 3*2=12 3*3=21

请注意,乘法表中两个数相乘的顺序必须为样例中所示的顺序,不能随意交换两个乘数。

给定 P,请输出 P 进制下的乘法表。

输入格式

输入一个整数 P。

输出格式

输出 P 进制下的乘法表。P 进制中大于等于 1010 的数字用大写字母 ABC、⋯⋯ 表示。

输入输出样例

输入 #1

复制代码
4

输出 #1

复制代码
1*1=1
2*1=2 2*2=10
3*1=3 3*2=12 3*3=21

输入 #2

复制代码
8

输出 #2

复制代码
1*1=1
2*1=2 2*2=4
3*1=3 3*2=6 3*3=11
4*1=4 4*2=10 4*3=14 4*4=20
5*1=5 5*2=12 5*3=17 5*4=24 5*5=31
6*1=6 6*2=14 6*3=22 6*4=30 6*5=36 6*6=44
7*1=7 7*2=16 7*3=25 7*4=34 7*5=43 7*6=52 7*7=61

说明/提示

对于所有评测数据, 2≤�≤362≤P≤36。

蓝桥杯 2020 第三轮省赛 AB 组 G 题。

解题思路:

首先我们需要知道,10进制转化为n进制的方法。以180转化为6进制为例。

180 % 6 = 0

180 / 6 = 30

30 % 6 = 0

30 / 6 = 5

5 % 6 = 5

5 / 5 = 0

将取到的模数调转,就变成500.那么180的6进制形式就是500。

我们可以很轻易的得到乘法表的打印方法(由两个for循环嵌套),我们将乘数与得到的答案进行进制转化,。需要注意的是如果超过10进制,后序会有ABC此类。我们可以通过ASCLL码进行转化。

样例代码:

cpp 复制代码
#include <iostream>
#include <stdio.h>
#include <algorithm>
using namespace std;

string jinzhi(int k, int n)//待转换进制的数,转换进制
{
	string sum;
	while (k)
	{
		int add = k % n;
		if (add >= 10)
		{
			sum += add - 10 + 'A';
		}
		else
		{
			sum += add + '0';
		}
		k = k / n;
	}
	reverse(sum.begin(),sum.end());
	return sum;
}

int main()
{
	int n;
	cin >> n;
	for (int i = 1; i < n; i++)
	{
		for (int j = 1; j <= i; j++)
		{
			cout << jinzhi(i , n) << '*' << jinzhi(j, n) << '=' << jinzhi(i * j, n) << ' ';
		}
		printf("\n");
	}
	return 0;
}
相关推荐
求职小程序华东同舟求职12 小时前
互联网校招腾讯26届校招暑期实习综合素质测评答题攻略及真题题库
面试·职场和发展·求职招聘·求职
测试199812 小时前
2025软件测试面试题汇总(接口测试篇)
自动化测试·软件测试·python·测试工具·面试·职场和发展·接口测试
GalaxyPokemon13 小时前
LeetCode - LCR 173. 点名
算法·leetcode·职场和发展
骑驴看星星a14 小时前
P10987 [蓝桥杯 2023 国 Python A] 火车运输
职场和发展·蓝桥杯
爱coding的橙子18 小时前
每日算法刷题Day31 6.14:leetcode二分答案2道题,结束二分答案,开始枚举技巧,用时1h10min
算法·leetcode·职场和发展
潘小磊19 小时前
高频面试之6Hive
大数据·hive·面试·职场和发展
a东方青2 天前
[蓝桥杯 2023 国 B] AB 路线 (BFS)
c++·算法·职场和发展·蓝桥杯·宽度优先
独行soc2 天前
2025年渗透测试面试题总结-字节跳动[实习]安全研发员(题目+回答)
linux·科技·安全·面试·职场和发展·渗透测试
潘小磊2 天前
高频面试之12 HBase
面试·职场和发展·hbase