蓝桥杯每日一题2023.9.16

蓝桥杯2022年第十三届省赛真题-X进制减法 - C语言网 (dotcpp.com)

题目描述

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

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

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

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

分析

可知对于A - B取到最小值需要其进制数取到最小

(以下为参考文章)

选取最小进制

选取其中最大的进制是因为A与B同进制,要保证进制合法

因此两者数据间只有选最大的那个数据才能保证两者相同

比如 6与8,我们只有选择8的进制我们才能同步两者的进制.

是在保证进制合法的情况下选择最小的进制

而题目意思中的十进制输入只是我们认为输入的数据,但是题设中的意思是我们实际上不知道它是什么进制

而为了所求相减最小,我们就选最小的进制,也就是保证两者相同时选择最小的进制,也就是加1.

加1是因为如果仅仅赋值输入的数据不可能的,注意有进位这个东西,不加1数据早就进位了

如我们看到的9这个数字,那么它最小的进制只可能是10,如果是9进制,是会直接进位的,

这样我们是看不见这个数字9的,看见的是进位后的结果

cpp 复制代码
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 1e5 + 10, M = 1000000007; 
ll n, ma, mb, sum, a[N], b[N], jz[N];
int main()
{
	ios::sync_with_stdio(0), cin.tie(0), cout.tie(0);
	cin >> n;
	cin >> ma;
	for(int i = ma; i >= 1; i --)cin >> a[i];
	cin >> mb;
	for(int i = mb; i >= 1; i --)cin >> b[i];
	//以下为找最小进制的过程,由于A >= B 
	for(int i = ma; i >= 1; i --)
	{
		jz[i] = max(max(a[i] + 1, b[i] + 1), 2ll);//最小为二进制 
	}
	for(int i = ma; i >= 2;  i--)
	{
		sum = ((sum + a[i] - b[i]) * jz[i - 1]) % M; 
	}
	sum += (a[1] - b[1]);//最低为直接将结果加起来 
	sum %= M;
	cout << sum;
	return 0;
}
相关推荐
计算机安禾5 小时前
【C语言程序设计】第27篇:递归函数原理与实例分析
c语言·开发语言·数据结构·c++·算法·蓝桥杯·visual studio
無限進步D5 小时前
C++ 万能头
开发语言·c++·算法·蓝桥杯·竞赛·万能头
TracyCoder1235 小时前
LeetCode Hot100(69/100)—— 139. 单词拆分
算法·leetcode·职场和发展
历程里程碑5 小时前
Linux 38 网络协议:从独立主机到全球互通
java·linux·运维·服务器·网络·c++·职场和发展
故事和你9114 小时前
sdut-程序设计基础Ⅰ-实验五一维数组(8-13)
开发语言·数据结构·c++·算法·蓝桥杯·图论·类和对象
仰泳的熊猫20 小时前
题目2270:蓝桥杯2016年第七届真题-四平方和
c++·算法·蓝桥杯
Aaswk21 小时前
蓝桥杯2025年第十六届省赛真题(更新中)
c语言·数据结构·c++·算法·职场和发展·蓝桥杯
hqyjzsb1 天前
AI产品经理成长路径:如何从零打造属于自己的AI项目经验。
人工智能·职场和发展·产品经理·创业创新·学习方法·信息与通信·业界资讯
酉鬼女又兒1 天前
HTML基础实例样式详解零基础快速入门Web开发(可备赛蓝桥杯Web应用开发赛道) 助力快速拿奖
前端·javascript·职场和发展·蓝桥杯·html·html5·web
滴滴答滴答答1 天前
机考刷题之 23&24&25 LeetCode 55&213&123
算法·leetcode·职场和发展