xtu oj 1353 Digit String

题目描述

小明获得了一些密码的片段,包含0∼9,A∼F 这些字符,他猜这些是某个进制下的一个整数的数码串。 小明想知道从2到16进制中,哪些进制下,这个数码串的对应的十进制整数值,等于n?

输入

存在不超过1000个样例,每行一个样例。 每行包括两部分,数码串(串长不超过31),整数n(1≤n≤109)

输出

每行输出一个样例的结果。 如果存在多个解,输出最小的那个进制。 如果没有满足的进制,输出"Impossible"。

样例输入

复制代码
F 15
F 14
23 11
25 13

样例输出

复制代码
16
Impossible
4
Impossible
cs 复制代码
#include<stdio.h>
#include<string.h>
#define ll long long
int main(){
	char s[32]={};
	while(scanf("%s",s)!=EOF){
		int la=strlen(s);
		int n,i;
		scanf("%d",&n);
		ll a[1005]={};
		for(i=0;i<la;i++){
			if(s[i]>='A'&&s[i]<='F')a[i]=s[i]-'A'+10;
			else a[i]=s[i]-'0';
		}
		ll max=0;
		for(i=0;i<la;i++){
			if(a[i]>max)max=a[i];
		}
		int b,flag=1;
		for(b=max+1;b<=16;b++){
			ll sum=0;
			for(i=0;i<la;i++){
				sum=sum*b+a[i];
			}
			if(sum==n){
				flag=0;
				printf("%d\n",b);
				break;
			}
		}
		if(flag)printf("Impossible\n");
	}
} 

int 会溢出,用long long。数必须小于进制。

相关推荐
2301_810730102 小时前
python第四次作业
数据结构·python·算法
adam_life2 小时前
区间动态# P1880 [NOI1995] 石子合并】
算法
坠金2 小时前
递归、递归和回溯的区别
算法
春栀怡铃声2 小时前
认识二叉树~
c语言·数据结构·经验分享·c·编译
恋爱绝缘体12 小时前
Java语言提供了八种基本类型。六种数字类型【函数基数噶】
java·python·算法
仰泳的熊猫2 小时前
题目1434:蓝桥杯历届试题-回文数字
数据结构·c++·算法·蓝桥杯
星火开发设计2 小时前
格式化输入输出:控制输出精度与对齐方式
开发语言·c++·学习·算法·函数·知识
ygklwyf2 小时前
模拟退火算法零基础快速入门
数据结构·c++·算法·模拟退火算法
XX風2 小时前
3.3 GMM (高斯混合模型)
人工智能·算法·机器学习
曾浩轩2 小时前
C语言学习记录——BC119 最高分与最低分之差
c语言·笔记·学习