P1154 奶牛分厩

题目链接

题面:

 

换句话说:

  给定n和长度为n的数组a , 你要求出最小的k使得,没有两个a[i] 、a[j] 会满足:a[i] % k = a[j] % k

思路:

  

  所以,求出数组a的两两差值x,x的所有因子都不满足条件

  然后遍历找第一个满足条件的k

代码:

  一开始是枚举差值,找他的所有因子进行标记,但是开了o2还是又一个点T,这是90分的代码:

  

#include<bits/stdc++.h>
using namespace std;
const int maxn =  1e6 + 10;
#define ll long long
#define ios std::ios::sync_with_stdio(false)
const ll INF(0x3f3f3f3f3f3f3f3fll);
const int inf(0x3f3f3f3f);

int a[maxn];
int cha[maxn];
int ans[maxn];
vector<int>vec[maxn];
int vis[maxn];
signed main()
{
    ios;
    cin.tie(0);
    int n;
    cin >> n;
    for(int i = 1 ; i <= n ; i ++) cin >> a[i];
    for(int i = 1 ; i <= n ; i ++){
        for(int j = i + 1 ; j <= n ; j ++){
            int now = abs(a[j] - a[i]);
            if(vis[now])continue;
            vis[now] ++;
            ans[now] ++;
            for(int k = 2 ; k * k <= now ; k ++){
                if(now % k == 0){
                    ans[k] ++;
                    if(now / k != k) ans[now / k] ++;
                }
            }
        }
    }
    for(int i = n ; i <= 1e6 ; i ++){
        if(!ans[i]){
            cout << i <<'\n';
            break;
        }
    }
    return 0;
}
View Code

  后来看了题解别人的写法发现 , 先标记下差值,然后从n开始枚举k , 判断k的倍数是否被标记过 , 如果没有,就是答案,这样就过了QAQ , 这是AC的:

#include<bits/stdc++.h>
using namespace std;
const int maxn =  1e6 + 10;
#define ll long long
#define ios std::ios::sync_with_stdio(false)
const ll INF(0x3f3f3f3f3f3f3f3fll);
const int inf(0x3f3f3f3f);

int a[maxn];
int cha[maxn];
int ans[maxn];
vector<int>vec[maxn];
int vis[maxn];
signed main()
{
    ios;
    cin.tie(0);
    int n , maxx = 0;
    cin >> n;
    for(int i = 1 ; i <= n ; i ++) cin >> a[i] , maxx = max(maxx , a[i]);
    for(int i = 1 ; i <= n ; i ++){
        for(int j = i + 1 ; j <= n ; j ++){
            int now = abs(a[j] - a[i]);
            if(vis[now])continue;
            vis[now] ++;
            ans[now] ++;
        }
    }
    for(int i = n ; i <= maxx ; i ++){
        bool ok = true;
        for(int j = i ; j <= maxx ; j += i){
            if(ans[j]){
                ok = false;
                break;
            }
       }
       if(ok){
            cout << i << '\n';
            break;
       }
    }
    return 0;
}
View Code

 

posted @ 2020-09-01 12:30  GoodVv  阅读(133)  评论(0编辑  收藏  举报