zoukankan      html  css  js  c++  java
  • 10.25 分组

    #include <bits/stdc++.h>
    using namespace std;
    
    typedef long long LL;
    
    #define N 131073
    
    int n, m = 0, K;
    int a[N], b[N];
    bool vis[N], dvis[N], issqr[N * 2];
    int f[N * 2];
    
    int getf(int x) {return f[x] > 0 ? (f[x] = getf(f[x])) : x;}
    
    void merge(int u, int v) {
        u = getf(u), v = getf(v);
        if (u != v) {
            if (f[u] > f[v]) swap(u, v);
            f[u] += f[v];
            f[v] = u;
        }
    }
    
    bool check(int u, int v) {
        int s1 = getf(u), s2 = getf(u + N);
        int t1 = getf(v), t2 = getf(v + N);
        if (s1 == t1) return 1;
        if (s2 == t2) return 1;
        merge(s1, t2); merge(s2, t1);
        return 0;
    }
    
    void solve_1() {
        for (int i = n, j = n; i;) {
            for (bool flag = 1; j; j--) {
                for (int k = 1; k * k - a[j] < N; k++) {
                    if (k * k - a[j] <= 0) continue;
                    if (vis[k * k - a[j]]) {flag = 0; break;} 
                }
                if (!flag) break;
                vis[a[j]] = 1;
            }
            if (!j) break;
            b[++m] = j;
            for ( ; i > j; i--) vis[a[i]] = 0;
        }
    }
    
    void solve_2() {
        memset(f, -1, sizeof f);
        for (int i = 1; i * i < 2 * N; i++) issqr[i * i] = 1;
        for (int i = n, j = n; i;) {
            for (bool flag = 1; j; j--) {
                if (vis[a[j]]) {
                    if (issqr[a[j] + a[j]]) {
                        if (dvis[a[j]]) break;
                        for (int k = 1; k * k - a[j] < N; k++) {
                            if (k * k - a[j] <= 0) continue;
                            if (vis[k * k - a[j]] && k * k != a[j] * 2) {
                                flag = 0; break;
                            } 
                        }
                        if (!flag) break;
                        dvis[a[j]] = 1;
                    }
                }
                else {
                    for (int k = 1; k * k - a[j] < N; k++) {
                        if (k * k - a[j] <= 0) continue;
                        if (vis[k * k - a[j]]) {
                            if (check(k * k - a[j], a[j])) {flag = 0; break;}
                        } 
                    }
                    if (!flag) break;
                    vis[a[j]] = 1;
                }
            }
            if (!j) break;
            b[++m] = j;
            for ( ; i > j; i--) f[a[i]] = f[a[i] + N] = -1, vis[a[i]] = 0, dvis[a[i]] = 0;
        }
    }
    
    int main() {
        freopen("division.in", "r", stdin);
        freopen("division.out", "w", stdout);
        scanf("%d%d", &n, &K);
        for (int i = 1; i <= n; i++) scanf("%d", a + i);
        if (K == 1) solve_1();
        else solve_2();
        printf("%d
    ", m + 1);
        for (int i = m; i; i--) printf("%d ", b[i]);
        putchar('
    ');
        return 0;
    }
  • 相关阅读:
    Unity3D游戏-愤怒的小鸟游戏源码和教程(一)
    Unity插件-ShareSDK使用指南
    Unity 3D开发-C#脚本语言的一些基础用法
    Shader的函数公式以及使用的场景
    Shader的基本用法和语法结构
    iTween的用法总结
    Unity 3D游戏-消消乐(三消类)教程和源码
    Unity 3D游戏-NPC对话系统With XML
    XML教程、语法手册、数据读取方式大全
    ReSharper2017.3的列对齐、排版格式、列对齐错误的修复
  • 原文地址:https://www.cnblogs.com/lyqlyq/p/7729666.html
Copyright © 2011-2022 走看看