P8723 [蓝桥杯 2020 省 AB3] 乘法表
P8723 [蓝桥杯 2020 省 AB3] 乘法表
#include <iostream>
using namespace std;
#include <string>
#include <vector>
#include <algorithm>
#include <format>
string toBaseP(int n,int p){//这里不要取引用,因为会改变值
if(n == 0) return 0;
string res = "";
while(n){
int mod = n %p;
res += (mod < 0?mod + '0':mod -10 + 'A');
n /=p;
}
reverse(res.begin(),res.end());
return res;
}
int main(){
int n;
cin>>n;
for(int i=1;i<=n-1;i++){
for(int j =1;j<=i;j++){
int a = i *j;
cout<<format("{}*{}={} ",toBaseP(i,n),toBaseP(j,n),toBaseP(a,n));
/*这里的 n 是通过引用传递的(int &n),意味着在函数内部修改 n 会直接改变调
用时的实际参数值。这在转换进制的过程中会破坏原始的值,
导致调用 toBaseP 后 i 和 j 的值被修改。 */
//cout<<i<<"*"<<j<<"="<<a/n<<a%n<<" ";
}
cout<<endl;
}
}
C++ 中允许将字符和整数直接进行算术运算,这是因为字符在底层被存储为整数(ASCII 值)。通过这种特性,简单的数学运算就可以实现字符和数字的转换。