D. Buying Shovels
传送门
- 题目大意:求最大的数q,满足:小于等于k,是n的因数,输出n/q。(n/q的最小值)
- 思路:如果k大于等于n,答案是1.
否则,从小到大遍历所有答案i,(i*q==n)
- 如果这个答案满足要求,输出。
- 始终维护q的最小值(n/i)。如果遍历所有答案后找不到一个能够小于等于k的q(都不满足情况1),那么答案就是维护的q的最小值。
#include<cassert>
#include<string>
#include<cmath>
#include<cstring>
#include<stack>
#include<iostream>
#include<queue>
#include<map>
#include<set>
#include<algorithm>
#include<vector>
#include<cstdlib>
#pragma warning(disable:4996)
#define inf 0x3f3f3f3f
#define linf 0x3f3f3f3f3f3f3f
#define itn int
#define ll long long
#define mes(a,k) memset(a,k,sizeof(a))
#define eps 1e-9
#define PI acos(-1)
using namespace std;
const int N = 2e5 + 5;
using namespace std;
void io(){ ios::sync_with_stdio(false), cin.tie(0), cout.tie(0);}
int main(){
io();
int T;
cin>>T;
ll a,b;
while(T--){
cin>>n>>k;
if(n<=k){
cout<<1<<endl;
continue;
}
int flg=0;
ll ans=linf;
for(int i=1;i<=sqrt(n);i++){
if(n%i==0){
if(n/i<=k){
cout<<i<<endl;
flg=1;
break;
}
if(i<=k){
ans=min(ans,n/i);
}
}
}
if(!flg){
cout<<ans<<endl;
}
}
}