X进制减法

进制规定了数字在数位上逢几进一。

X 进制是一种很神奇的进制,因为其每一数位的进制并不固定!例如说某种 X 进制数,最低数位为二进制,第二数位为十进制,第三数位为八进制,则 X 进制数 321 转换为十进制数为 65。

现在有两个 X 进制表示的整数 A 和 B,但是其具体每一数位的进制还不确定,只知道 A 和 B 是同一进制规则,且每一数位最高为 N 进制,最低为二进制。请你算出 A−B 的结果最小可能是多少。

请注意,你需要保证 A 和 B 在 X 进制下都是合法的,即每一数位上的数字要小于其进制。

输入格式
第一行一个正整数 N,含义如题面所述。

第二行一个正整数 Ma,表示 X 进制数 A 的位数。

第三行 Ma 个用空格分开的整数,表示 X 进制数 A 按从高位到低位顺序各个数位上的数字在十进制下的表示。

第四行一个正整数 Mb,表示 X 进制数 B 的位数。

第五行 Mb 个用空格分开的整数,表示 X 进制数 B 按从高位到低位顺序各个数位上的数字在十进制下的表示。
请注意,输入中的所有数字都是十进制的。
输出格式
输出一行一个整数,表示 X 进制数 A−B 的结果的最小可能值转换为十进制后再模 1000000007 的结果。
样例输入
11
3
10 4 0
3
1 2 0
样例输出
94
样例说明
当进制为:最低位 2 进制,第二数位 5 进制,第三数位 11 进制时,减法得到的差最小。此时 A 在十进制下是 108,B 在十进制下是 14,差值是 94。
评测用例规模与约定
对于 30% 的数据,N≤10,Ma,Mb≤8;
对于 100% 的数据,2≤N≤1000,1≤Ma,Mb≤100000,A≥B。

#include
#define mod 1000000007
using namespace std;
typedef long long l;
l jw[1000001];
l a[1000001];
l b[1000001];
l max_a[1000001];
l max_b[1000001];
l c[1000001];
l gs1;
l gs2;
int main()
{
l x;
cin>>x;
cin>>gs1;
for(int i=1;i<=gs1;i++)
cin>>a[i];
cin>>gs2;
for(int i=1;i<=gs2;i++)
cin>>b[i];
for(int j=gs1,k=gs2;j>=1 || k>=1;) //计算每一位的进制规则
{
if(k>=1 && j>=1) //都在范围内
{
int max_ab = max(a[j],b[k]);
if(max_ab == 0 || max_ab == 1)
{
max_a[j] = 2;
max_b[k] = 2;
}
else
{
max_a[j] = (max_ab + 1)%mod;
max_b[k] = (max_ab + 1)%mod;
}
k–,j–;
}
else if(k == 0)
{ if(a[j]!=1 && a[j]!=0)
max_a[j] = a[j] + 1;
else
max_a[j] = 2;
j–;
}
else if(j == 0)
{
if(b[k]!=1 && b[k]!=0)
max_b[k] = b[k] + 1;
else
max_b[k] = 2;
k–;
}
}
l sum1 = 0;
l sum = 1;
int cha = gs1 - gs2; //计算位差
for(int i=1;i<=gs1;i++)
{ if(i-cha>=1) //当两个数字对齐时差值为两者相减
c[i] = a[i] - b[i-cha];
else //否则为a对应位的值
c[i] = a[i];
}
for(int j=gs1;j>=1;j–)
{
sum1 = (sum1 + sum * c[j])%mod;
sum = (sum * max_a[j])%mod;
}

cout<<sum1%mod;
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值