题目传送门

sol1:老实做,预处理出所有2到1e5的素数,对所有数进行分解质因数,然后对比因子个数。感觉有点卡常,用了快读然后多次优化之后才过的,map也用上了。

  • 素数筛,快速分解质因数

    #include "bits/stdc++.h"
    using namespace std;
    typedef long long LL;
    const int MAXN = 1e5 + ;
    bool v[MAXN];
    map<int, int> mp;
    int p[MAXN], pos;
    int a[MAXN], b[MAXN];
    LL ca[MAXN], cb[MAXN];
    void init() {
    for (int i = ; i <= 1e5; i++) {
    if (v[i] == false) {
    p[++pos] = i;
    mp[i] = pos;
    for (int j = i << ; j <= 1e5; j += i)
    v[j] = true;
    }
    }
    }
    inline int read() {
    int n = ;
    char c = getchar();
    while (c < '' || c > '') c = getchar();
    while (c >= '' && c <= '') {
    n = n * + (c ^ '');
    c = getchar();
    }
    return n;
    }
    void fun(int k, int c, LL* a) {
    for (int i = ; v[k]; i++) {
    while (k % p[i] == ) {
    k /= p[i];
    a[i] += c;
    }
    }
    if (k != ) a[mp[k]] += c;
    }
    int main() {
    init();
    int t, n, m, k;
    t = read();
    while (t--) {
    n = read(), m = read();
    memset(ca, , sizeof(LL) * (pos + ));
    memset(cb, , sizeof(LL) * (pos + ));
    for (int i = ; i <= n; i++) a[i] = read();
    for (int i = ; i <= m; i++) b[i] = read();
    sort(a + , a + + n);
    sort(b + , b + + m);
    k = ;
    for (int i = ; i <= a[n]; i++) {
    while (i > a[k]) k++;
    fun(i, n - k + , ca);
    }
    k = ;
    for (int i = ; i <= b[m]; i++) {
    while (i > b[k]) k++;
    fun(i, m - k + , cb);
    }
    bool ok = true;
    for (int i = ; i <= pos; i++) {
    if (ca[i] != cb[i]) {
    ok = false;
    break;
    }
    }
    if (ok) puts("equal");
    else puts("unequal");
    }
    return ;
    }

sol2:题解上说用哈希。虽然一开始也有想到哈希,但是怕哈希冲突,没怎么在比赛中用过哈希,没有哈希的意识。知道用哈希之后代码就信手拈来了,不过还是产生了一次哈希冲突,不要用1e9 + 7这种特殊素数,决定还是使用2147483587(int范围第二大的素数,怕最大的会被卡)。

  • 哈希

    #include "bits/stdc++.h"
    using namespace std;
    const int MAXN = 1e5 + ;
    const int MOD = ;
    int a[MAXN], b[MAXN];
    int quick_pow(int n, int k) {
    int ans = ;
    while (k) {
    if (k & ) ans = 1LL * ans * n % MOD;
    n = 1LL * n * n % MOD;
    k >>= ;
    }
    return ans;
    }
    int main() {
    int t, n, m, k;
    scanf("%d", &t);
    while (t--) {
    scanf("%d%d", &n, &m);
    for (int i = ; i <= n; i++)
    scanf("%d", &a[i]);
    for (int i = ; i <= m; i++)
    scanf("%d", &b[i]);
    sort(a + , a + + n);
    sort(b + , b + + m);
    int ha = , hb = ;
    k = ;
    for (int i = ; i <= a[n]; i++) {
    while (i > a[k]) k++;
    ha = 1LL * ha * quick_pow(i, n - k + ) % MOD;
    }
    k = ;
    for (int i = ; i <= b[m]; i++) {
    while (i > b[k]) k++;
    hb = 1LL * hb * quick_pow(i, m - k + ) % MOD;
    }
    if (ha == hb) puts("equal");
    else puts("unequal");
    }
    return ;
    }

牛客-小w的a=b问题的更多相关文章

  1. 牛客 小a与星际探索 bfs

    链接:https://ac.nowcoder.com/acm/contest/317/C?&headNav=acm来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C++ ...

  2. 牛客 小a与星际探索

    链接:https://ac.nowcoder.com/acm/contest/317/C来源:牛客网 小a正在玩一款星际探索游戏,小a需要驾驶着飞船从1号星球出发前往n号星球.其中每个星球有一个能量指 ...

  3. 牛客-小a的旅行计划 + 数学推导

    小a的旅行计划 题意: 小a终于放假了,它想在假期中去一些地方游玩,现在有N个景点,编号为,同时小b也想出去游玩.由于一些特殊♂原因,他们的旅行计划必须满足一些条件 首先,他们可以从这N个景点中任意选 ...

  4. 牛客-小y的盒子

    题目传送门 -------------------稍加观察就会发现,4n - 1就是题目要的答案.至于为什么,看官方的题解.不过这个n非常的大,用正常快速幂解决不了.这道题我学到的就是解决幂非常大的情 ...

  5. 牛客练习赛48 C 小w的糖果 (数学,多项式,差分)

    牛客练习赛48 C 小w的糖果 (数学,多项式) 链接:https://ac.nowcoder.com/acm/contest/923/C来源:牛客网 题目描述 小w和他的两位队友teito.toki ...

  6. 牛客练习赛48 A· 小w的a+b问题 (贪心,构造,二进制)

    牛客练习赛48 A· 小w的a+b问题 链接:https://ac.nowcoder.com/acm/contest/923/A来源:牛客网 时间限制:C/C++ 1秒,其他语言2秒 空间限制:C/C ...

  7. 牛客练习赛48 D 小w的基站网络

    链接:https://ac.nowcoder.com/acm/contest/923/D来源:牛客网 时间限制:C/C++ 2秒,其他语言4秒 空间限制:C/C++ 262144K,其他语言52428 ...

  8. 【牛客】小w的魔术扑克 (并查集?? 树状数组)

    题目描述 小w喜欢打牌,某天小w与dogenya在一起玩扑克牌,这种扑克牌的面值都在1到n,原本扑克牌只有一面,而小w手中的扑克牌是双面的魔术扑克(正反两面均有数字,可以随时进行切换),小w这个人就准 ...

  9. 牛客小白月赛13 小A的柱状图(单调栈)

    链接:https://ac.nowcoder.com/acm/contest/549/H来源:牛客网 题目描述 柱状图是有一些宽度相等的矩形下端对齐以后横向排列的图形,但是小A的柱状图却不是一个规范的 ...

随机推荐

  1. csv文件——简单读操作01

    转载:https://www.py.cn/spider/advanced/14381.html import csv with open('C:\\Users\\del\\Desktop\\123.c ...

  2. Java面向对象(概述,构造函数,类与对象的关系,this关键字,成员、局部),匿名对象的调用,构造代码块(5)

    Java面向对象(概述,构造函数,类与对象的关系,this关键字,成员.局部),匿名对象的帝爱用,构造代码块(5)

  3. EOF是什么?(笔记)

    一.参考文章 1.EOF是什么?(阮一峰网络日志) 2.Linux 中的 EOF 到底是什么 二.知识点 1.EOF 定义在 /usr/include/stdio.h 文件中: 从上面 EOF 的定义 ...

  4. Linux系统相关命令

    时间和日期 date cal 磁盘和目录空间 df du 进程信息 ps top kill 01. 时间和日期 序号 命令 作用 01 date 查看系统时间 02 cal calendar 查看日历 ...

  5. Println(Object)小贴士

    println public void println(Object x) 打印 Object,然后终止该行.此方法首先调用 String.valueOf(x) 获取打印对象的字符串值,然后的行为如同 ...

  6. JS 日期格式化为 2020-11-01 22:33:44 格式

    项目中经常会用到将JS日期格式化输出为 标准格式(2020-11-01 22:33:44)的问题.写个精简版的,代码如下: function formatDate(d){ d = d || new D ...

  7. 吴裕雄--天生自然 JAVA开发学习:修饰符

    public class InstanceCounter { private static int numInstances = 0; protected static int getCount() ...

  8. PAT Advanced 1056 Mice and Rice (25) [queue的⽤法]

    题目 Mice and Rice is the name of a programming contest in which each programmer must write a piece of ...

  9. layui select恢复默认值

  10. python格式化输出的三种形式

    法一: list_a = [1, 2, 3] str_b = 'aaa' string = "There are two contents:%s, %s" % (list_a, s ...