xtu oj 1394 单调
2023-12-22 06:52:20
单调
题目描述
n=∑ki=0ai?bi,b≥2,如果i>0时,ai>ai?1,那么我们称这个数n是在b进制下是单调的。比如6,在3进制下为20(3),所以6在3进制下是单调的。现在已知n,求最小的基b,使得n是单调的。
输入
第一行是一个整数T(1≤T≤10000),表示样例的个数。 每行一个整数n,2≤n≤109。
输出
依次每行输出一个样例的结果。
样例输入
2
2
1000000000
样例输出
2
32
AC代码
#include<stdio.h>
int main()
{
int T;
scanf("%d",&T);
while(T--){
int n;
scanf("%d",&n);
int t,i,j,k,b,flag;
for(b=2;;b++){
int a[105]={};
t=n,k=0,flag=1;
while(t!=0){
a[k]=t%b;
t/=b;
k++;
}
for(i=0;i<k-1&&flag;i++){
for(j=i+1;j<k;j++){
if(a[i]>=a[j]){
flag=0;
break;
}
}
}
if(flag){
printf("%d\n",b);
break;
}
}
}
}
进制转换,注意,数组比较的时候应该是后一位数比前一位数小不满足,比如转换后的进制数是234,这显然是不满足的。理清楚对应关系就好。int 的范围是大于10的9次方的,如果出现大数相乘,相加,一般都要用long long类型。
文章来源:https://blog.csdn.net/m0_75005390/article/details/135142759
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。 如若内容造成侵权/违法违规/事实不符,请联系我的编程经验分享网邮箱:veading@qq.com进行投诉反馈,一经查实,立即删除!