IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 数据结构与算法 -> cf Round #775 Div.2 -D【逆向思维+简单数学】 -> 正文阅读

[数据结构与算法]cf Round #775 Div.2 -D【逆向思维+简单数学】

Date:2022.03.06
题意:给一个数组,是否能满足其中任意两个元素x>=y保证 ? x y ? \lfloor \frac{x}{y} \rfloor ?yx??存在于数组中。
在这里插入图片描述
思路:打表每个数的倍数(保证<=最大值),找性质。以样例中的1 3 3 7为例,打表如下:
1 2 3 4 5 6 7
3 6
3 6
7
我们再以3 6为例,分别是 3 × 1 、 3 × 2 3\times1、3\times2 3×13×2,这里的1、2即代表数组中是否能有数 ? ? ?使得 ? / 3 = = 1 、 2 ?/3==1、2 ?/3==12,且 1 、 2 1、2 12也在数组中【否则不合法】?我们再以 ? / 3 = = 2 ?/3==2 ?/3==2为例,显然 ? ∈ [ 2 × 3 , 2 × 3 + 2 ] ?\in[2 \times 3,2 \times 3+2] ?[2×3,2×3+2],因此问题转换为:判断每个数 a [ i ] a[i] a[i]的所有倍数 x ( < = c ) x(<=c) x(<=c)在对应的 [ x , m i n ( c , x + a [ i ] ? 1 ) ] [x,min(c,x+a[i]-1)] [x,min(c,x+a[i]?1)]区间下是否有至少 1 1 1个数 x ′ x' x(有数才能继续判断 x ′ / a [ i ] x'/a[i] x/a[i]是否在数组中),使得 x ′ / a [ i ] x'/a[i] x/a[i]也在数组中,若不在则不合法(即产生了不存在于数组中的值)。判断区间是否有至少1个数就乱搞一个前缀和判定区间中有几个元素存在于数组中即可。
至于复杂度,由于 c / 1 + c / 2 + c / 3 + . . . + c / c c/1+c/2+c/3+...+c/c c/1+c/2+c/3+...+c/c,调和级数大概是 O ( c ? l n ( c + 1 ) ) O(c*ln(c+1)) O(c?ln(c+1))
此外,记得去重,重复元素显然毫无意义,不然tle14。

代码如下:

#include <bits/stdc++.h>
#define x first
#define y second
using namespace std;
typedef long long LL;
const LL N = 2e6+10,INF=0x3f3f3f3f3f3f3f3f;
typedef pair<LL, LL> PII;
LL t,n,m,k,a[N],c,cnt[N];
LL st[N],sumst[N];
int main()
{
    ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);
    cin>>t;
    while(t--)
    {
        cin>>n>>c;
        for(int i=1;i<=c;++i) {cnt[i]=0;st[i]=0;sumst[i]=0;}
        for(int i=1;i<=n;++i) {cin>>a[i];st[a[i]]=1;}
        for(int i=1;i<=c;++i) sumst[i]=sumst[i-1]+st[i];
        sort(a+1,a+1+n);LL len=unique(a+1,a+1+n)-a-1;
        bool flag=true;
        if(a[1]!=1) {cout<<"No"<<endl;continue;}
        for(int i=1;i<=len;++i)
        {
            for(int x=a[i],j=1;x<=c;x+=a[i],++j)
            {
                if(st[x/a[i]]) continue;
                if(sumst[min(x+a[i]-1,c)]-sumst[x-1]>0)//注意右边界不要越界,不然初始化比较难办
                {
                    if(!st[j]) {flag=false;break;}
                }
            }
            if(!flag) break;
        }
        if(flag) cout<<"Yes"<<endl;
        else cout<<"No"<<endl;
    }
    return 0;
}
  数据结构与算法 最新文章
【力扣106】 从中序与后续遍历序列构造二叉
leetcode 322 零钱兑换
哈希的应用:海量数据处理
动态规划|最短Hamilton路径
华为机试_HJ41 称砝码【中等】【menset】【
【C与数据结构】——寒假提高每日练习Day1
基础算法——堆排序
2023王道数据结构线性表--单链表课后习题部
LeetCode 之 反转链表的一部分
【题解】lintcode必刷50题<有效的括号序列
上一篇文章      下一篇文章      查看所有文章
加:2022-03-16 22:43:30  更:2022-03-16 22:48:58 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/9 16:07:55-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码