P8723 [蓝桥杯 2020 省 AB3] 乘法表
呈上篇,更高进制的乘法口诀表。主要思想在于进制的转换,用函数,数组来辅助本题思路更为清晰
#include"bits/stdc++.h"
using namespace std;
const int N=1000;
int a[N],p;//牵扯到更高进制的转换,这里直接用一个数组储存余数,然后输出更为简洁
void s(int n)
{
int ans=0;
while(n)//短除法
{
a[++ans]=n%p;
n=n/p;
}
for(int i=ans;i>=1;i--)//短除法转换进制时,需要倒过来输出
{
if(a[i]<10)
cout << a[i];
else
cout << (char)(a[i]+'A'-10);
/*余数大于9,说明为高进制转换,依题意转换成字母*/
}
}
int main()
{
cin >> p;
for(int i=1;i<p;i++)
{
for(int j=1;j<=i;j++)
{
if(i<10) cout << i;
else cout <<(char)('A'+i-10);//同上
cout << "*";
if(j<10) cout << j;
else cout <<(char)('A'+j-10);
cout <<"=";
s(i*j);
cout <<" ";//注意格式,其实这样写也不严谨,不过也跑过了,哈哈哈哈(严谨的格式参考上篇,主要是最后有无空格的细节)
}
cout << "\n";
}
return 0;
}