立方数(cubic)

Time Limit:1000ms   Memory Limit:128MB

题目描述

LYK定义了一个数叫“立方数”,若一个数可以被写作是一个正整数的3次方,则这个数就是立方数,例如1,8,27就是最小的3个立方数。

现在给定一个数P,LYK想要知道这个数是不是立方数。

当然你有可能随机输出一些莫名其妙的东西来骗分,因此LYK有T次询问~

输入格式(cubic.in)

第一行一个数T,表示有T组数据。

接下来T行,每行一个数P。

输出格式(cubic.out)

输出T行,对于每个数如果是立方数,输出“YES”,否则输出“NO”。

输入样例

3

8

27

28

输出样例

YES

YES

NO

数据范围

对于30%的数据p<=100。

对于60%的数据p<=10^6。

对于100%的数据p<=10^18,T<=100。

这个题应该是个送分题

我们看这个题的数据范围p是<=10^18的,因为这个题要求是x*x*x==n,所以我们·如果枚举x,时间复杂度是10^6的,再加上T<=100,那么我们的总时间复杂度是10^6*100也就是10^8,因此不会爆

O(≧口≦)O   zz啊、、忘了初始化了!

当使用多个while的时候,一定不要忘了初始化!!!!!!!!!

#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
inline long long read()
{
    ,f=; char ch=getchar();
    ') ch=getchar();
    +ch-',ch=getchar();
    return x*f;
}
int main()
{
    freopen("cubic.in","r",stdin);
    freopen("cubic.out","w",stdout);
    int T;
    bool flag;
    ;
    scanf("%d",&T);
    while(T--)
    {
        n=read();flag=;
        )
        {
            if(i*i*i==n)
            {
                flag=true;
                break;
            }
             else
             {
                 if(i*i*i<n) i++;
                 else break;
             }
        }
        if(flag) printf("YES\n");
        else printf("NO\n");
    }
    ;
}

AC代码

#include <bits/stdc++.h>
using namespace std;
long long A;
int T;
bool work(long long x)
{
    ; ; i++)
    {
        if (1ll*i*i*i==x) return true;
        if (1ll*i*i*i>x) return false;
    }
}
int main()
{
    freopen("cubic.in","r",stdin);
    freopen("cubic.out","w",stdout);
    scanf("%d",&T);
    while (T--)
    {
        scanf("%I64d",&A);
        if (work(A)) puts("YES"); else puts("NO");
    }
    ;
}

std

立方数2(cubicp)

Time Limit:1000ms   Memory Limit:128MB

题目描述

LYK定义了一个数叫“立方数”,若一个数可以被写作是一个正整数的3次方,则这个数就是立方数,例如1,8,27就是最小的3个立方数。

LYK还定义了一个数叫“立方差数”,若一个数可以被写作是两个立方数的差,则这个数就是“立方差数”,例如7(8-1),26(27-1),19(27-8)都是立方差数。

现在给定一个数P,LYK想要知道这个数是不是立方差数。

当然你有可能随机输出一些莫名其妙的东西,因此LYK有T次询问~

这个问题可能太难了…… 因此LYK规定P是个质数!

输入格式(cubicp.in)

第一行一个数T,表示有T组数据。

接下来T行,每行一个数P。

输出格式(cubicp.out)

输出T行,对于每个数如果是立方差数,输出“YES”,否则输出“NO”。

输入样例

5

2

3

5

7

11

输出样例

NO

NO

NO

YES

NO

数据范围

对于30%的数据p<=100。

对于60%的数据p<=10^6。

对于100%的数据p<=10^12,T<=100。

呜呜~~~~(>_<)~~~~

打了个暴力,应该全T了吧、、

我们要求的是x^3-y^3==p,看到这个式子,我们肯定能立即想到我们的立方差公式吧,据说在初中就学过的(呜呜,捂脸,我是一个小学生)

公式:

(a+b)(a²-ab+b²)=a³+b³
(a-b)(a²+ab+b²)=a³-b³
(a-b)^3=(a-b)(a-b)(a-b)=(a^2-2ab+b^2)(a-b)=a^3-3a^2b+3ab^2-b^3
(a+b)^3=a^3+3a^2b-3ab^2+b^3

我们可以看到我们上面的式子可以化为x^3-y^3=(x-y)*(a^2+a*b+b^2)=p,我们知道p是素数,那么p的因子便只有1和它本身,我们看式子,只能是x-y=1了,即y=x-1,所以上面的式子又可以化成(x^2+x*(x-1)+x^2)==p,这样我们又只需要10^6枚举x就好了!

#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
long long n,i,j,x,l;
inline long long read()
{
    ,f=; char ch=getchar();
    ') ch=getchar();
    +ch-',ch=getchar();
    return x*f;
}
int main()
{
    freopen("cubicp.in","r",stdin);
    freopen("cubicp.out","w",stdout);
    int T;bool flag;
    scanf("%d",&T);
    while(T--)
    {
        n=read();flag=;
        ) {flag=true; break;}
        ;i<=;i++)
        {
            ;
            ;j--)
             {
                 x=i*i*i-j*j*j;
                 if(x==n)
                 {
                     flag=true;
                     break;
                 }
                 else
                 if(x>n) break;
                  else l=j;
              }
         }
        if(flag) printf("YES\n");
        else printf("NO\n");
    }
    ;
}

TLE。。。

#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
long long n,x,y;
inline long long read()
{
    ,f=; char ch=getchar();
    ') ch=getchar();
    +ch-',ch=getchar();
    return x*f;
}
int main()
{
    freopen("cubicp.in","r",stdin);
    freopen("cubicp.out","w",stdout);
    int T;bool flag;
    scanf("%d",&T);
    while(T--)
    {
        n=read();flag=false;
        ) {flag=true; break;}
        ;x<=;x++)
        {
            y=x*x+x*(x-)+(x-)*(x-);
            if(y==n)
            {
                flag=true;
                break;
            }
            if(y>n) break;
         }
        if(flag) printf("YES\n");
        else printf("NO\n");
    }
    ;
}

AC代码

猜数字(number)

Time Limit:1000ms   Memory Limit:128MB

题目描述

LYK在玩猜数字游戏。

总共有n个互不相同的正整数,LYK每次猜一段区间的最小值。形如[li,ri]这段区间的数字的最小值一定等于xi。

我们总能构造出一种方案使得LYK满意。直到…… LYK自己猜的就是矛盾的!

例如LYK猜[1,3]的最小值是2,[1,4]的最小值是3,这显然就是矛盾的。

你需要告诉LYK,它第几次猜数字开始就已经矛盾了。

输入格式(number.in)

第一行两个数n和T,表示有n个数字,LYK猜了T次。
    接下来T行,每行三个数分别表示li,ri和xi。

输出格式(number.out)

输出一个数表示第几次开始出现矛盾,如果一直没出现矛盾输出T+1。

输入样例

20 4

1 10 7

5 19 7

3 12 8

1 20 1

输出样例

3

数据范围

对于50%的数据n<=8,T<=10。

对于80%的数据n<=1000,T<=1000。

对于100%的数据1<=n,T<=1000000,1<=li<=ri<=n,1<=xi<=n(但并不保证一开始的所有数都是1~n的)。

Hint

建议使用读入优化

inline int read()

{

int
x = 0, f = 1;

char
ch = getchar();

for(;
!isdigit(ch); ch = getchar()) if(ch == '-') f = -1;

for(;
isdigit(ch); ch = getchar()) x = (x << 1) + (x << 3) + ch - '0';

return
x * f;

}

线段树+二分答案

对于这种类型的问题,我们有两种做法,一种是枚举判断没一个加入以后是否可行,第二种方法是进行二分

1~mid出现矛盾,答案在l~mid中,否则答案一定出现在mid+1~r中。

判断性问题,给定一堆猜测,判断是否产生矛盾

按xi从小到大排序

怎么判断是否矛盾?

对于[l,r]之前已经被更大的·xi覆盖了,说明出现了矛盾

将所有xi相同的进行合并(取区间交)

从大到小枚举这个xi,判断比xi大的区间的并是否完全覆盖了这个区间

查询:区间最小值

修改:将一段区间修改为1

这个操作,我们可以用并查集进行维护,判断一个区间是否已经被一个更大的xi覆盖

#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#define N 1000011
using namespace std;
int read()
{
    ,f=;char ch=getchar();
    ;ch=getchar();}
    +ch-',ch=getchar();
    return  x*f;
}
struct Node
{
    int x,y,z;
}node[N],b[N];
int n,t,lmin,lmax,rmin,rmax,f[N];
int cmp(Node a,Node b)
{return a.z>b.z;}
int find(int x)
{
    if(f[x]==x) return x;
    f[x]=find(f[x]);
    return f[x];
}
int judge(int k)
{
    ;i<=n+;i++) f[i]=i;
    ;i<=k;i++) b[i]=node[i];
    sort(b+,b++k,cmp);
    lmin=lmax=b[].x;
    rmin=rmax=b[].y;
    ;i<=k;i++)
    {
        ].z)
        {
            ;
            for(int j=find(lmin);j<=rmax;j++)
             f[find(j)]=find(rmax+);
            lmin=lmax=b[i].x;
            rmin=rmax=b[i].y;
        }
        else
        {
            lmin=min(lmin,b[i].x);
            lmax=max(lmax,b[i].x);
            rmin=min(rmin,b[i].y);
            rmax=max(rmax,b[i].y);
            ;
        }
    }
    ;
    ;
}
int main()
{
    freopen("number.in","r",stdin);
    freopen("number.out","w",stdout);
    n=read(),t=read();
    ;i<=t;i++)
     node[i].x=read(),node[i].y=read(),node[i].z=read();
    ,r=t,mid,ans;
    while(l<=r)
    {
        mid=(l+r)>>;
        ;
        ;
    }
    printf("%d",ans);
    ;
}

AC代码

清北·NOIP2017济南考前冲刺班 DAY1 morning的更多相关文章

  1. 清北 Noip 2016 考前刷题冲刺济南班

    2016 10 29 周六 第一天 %%%,%ZHX大神 上午,60分, 下午,爆零orz 2016 10 30 周天 第二天 炒鸡倒霉的一天 %%%,%ZHX大神 据大神第一天的题最简单. 上午,和 ...

  2. noip济南清北冲刺班DAY1

    上午 T1 立方数 题目描述 LYK定义了一个数叫“立方数”,若一个数可以被写作是一个正整数的3次方,则这个数就是立方数,例如1,8,27就是最小的3个立方数. 现在给定一个数P,LYK想要知道这个数 ...

  3. 2016.10.29 清北学堂NOIP冲刺班Day1 AM 考试总结

    成绩:满分300,我得了200, 1:90//前两个题目都是模拟,没用到什么其他算法,第一题有可能少考虑了一点细节 2:100 3:10//感觉是个DP,但是毫无思路,只打了个普通背包,10分而已. ...

  4. 清北学堂2019NOIP提高储备营DAY1

    今天是第二次培训的第一天,关于NOIP的基础算法,主要内容如下: $1.枚举 $2.搜索 $3.贪心 $1.枚举: •定义: 枚举又叫做穷举,是一种基础的算法,其思路主要是:从问题中有可能的解集中一一 ...

  5. 【清北学堂2018-刷题冲刺】Contest 7

    Task 1:小奇采药 [问题描述]  小奇是只天资聪颖的喵,他的梦想是成为世界上最伟⼤的医师.  为此,他想拜喵星球最有威望的医师为师.  医师为了判断他的资质,给他出了⼀个难题.  医师把他带到⼀ ...

  6. 【清北学堂2018-刷题冲刺】Contest 6

    Task 1:子集 [问题描述]  若一个集合S中任意两个元素x和y,都满足x⊕y<min⁡(x, y) ,则称集合S是"好的".其中⊕为按位异或运算符.现在给定一个大小为n ...

  7. 【清北学堂2018-刷题冲刺】Contest 5

     这三个题写了一天半,第一个题写了大概一整天.出题人劝我从后往前写,我不听,结果T1想了+调了一天QWQWQ Task 1:序列 [问题描述]  定义一个"好的序列"为一个长度为M ...

  8. 【清北学堂2018-刷题冲刺】Contest 4

    Task 1:序列 [问题描述]  小H原本有一个由连续的正整数组成的序列,如{4,5,6}或{10,11,12,13,14,15,16},但是她最近睡眠不足,只能记得其中的一些数字.她想知道,她最少 ...

  9. 【清北学堂2018-刷题冲刺】Contest 3

     比较数学的一场,难度稍大. Task 1:数数 [问题描述]  fadbec 很善于数数,⽐如他会数将a 个红球,b 个黄球,c 个蓝球,d个绿球排成⼀列,求出任意相邻不同⾊的方案数⽬.  现在R ...

随机推荐

  1. 01--是时候让我们谈谈一致性hash了

    --------------------- 假如你有图中三个盒子,我们有代号为 1,4,5,12 这四样东西 那根据代号作为主键,将东西放到盒子了,该如何放置? 我们可以对代号取模 1 mod 3 = ...

  2. HDU 4699 Editor(双向链表)

    双向链表直接模拟. 用一个辅助数组maxSum来维护一下前k项中[1,k]的最大和. 因为光标是一格一格的移动,所以每次光标右移的时候动态更新一下即可. 时间复杂度O(n). #include < ...

  3. C#读取xml文件写入到TreeView中

    开发过程中我们会遇到一些读取xml文件的时候,下面是我学习的整理. 用XmlDocument读取加载 XmlDocument doc = new XmlDocument(); doc.Load(&qu ...

  4. 201621123034 《Java程序设计》第12周学习总结

    作业12-流与文件 1. 本周学习总结 1.1 以你喜欢的方式(思维导图或其他)归纳总结多流与文件相关内容. 2. 面向系统综合设计-图书馆管理系统或购物车 使用流与文件改造你的图书馆管理系统或购物车 ...

  5. [解决方案]IIS7.5 报错:无法启动计算机“."上的服务W3SVC

    报错场景: 在云服务器上,正常使用着,突然今天一打开网站就都用不了了,上去服务器一看,IIS中站点被停止了,我还怀疑是回收的问题,结果一直启动无果,我打算重启来解决这个问题,重启后发现所有站点都变成停 ...

  6. College student reflects on getting started in open source(一)

    I just completed the first semester of my second year in college, and I'm reflecting on what I learn ...

  7. python模块导入

    官方手册:https://docs.python.org/3/tutorial/modules.html 可执行文件和模块 python源代码文件按照功能可以分为两种类型: 用于执行的可执行程序文件 ...

  8. linux常用60条命令 转

    Linux必学的60个命令   Linux提供了大量的命令,利用它可以有效地完成大量的工作,如磁盘操作.文件存取.目录操作.进程管理.文件权限设定等.所以,在Linux系统上工作离不开使用系统提供的命 ...

  9. parallel programming. this causual litery nots represents my recent progress in parallel programming in c#.It`s interesting.

    not to say extra words,let`s start the code. pasted below: using System; using System.Collections.Ge ...

  10. linq使用 count与sum等

    using System; using System.Data; using System.Configuration; using System.Linq; using System.Web; us ...