noip提高组模拟赛                                                                                                                                                                                                                                                                     (不想改了,弃疗了、、)

                                            (哈哈,三个题打了三个暴力、、)

1.计数

(count.cpp/c/pas)

时间限制:1s

内存限制:256MB

【问题描述】

给出m个数a[1],a[2],…,a[m]

求1~n中有多少数不是a[1],a[2],…,a[m]的倍数。

【输入】

输入文件名为count.in。

第一行,包含两个整数:n,m

第二行,包含m个数,表示a[1],a[2],…,a[m]

【输出】

输出文件名为count.out。

输出一行,包含1个整数,表示答案

【输入输出样例】

count.in

count.out

10 2

2 3

3

【数据说明】

对于60%的数据,1<=n<=106

对于另外20%的数据,m=2

对于100%的数据,1<=n<=109,0<=m<=20,1<=a[i]<=109

#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<iostream>
#include<algorithm>
#define N 1000010
#define LL long long
using namespace std;
bool vis[N];
int n,m,x;
int read()
{
    ,f=; char ch=getchar();
    ; char ch=getchar();}
    +ch-',ch=getchar();
    return x*f;
}
int main()
{
    freopen("count.in","r",stdin);
    freopen("count.out","w",stdout);
    n=read(),m=read();
    int j,ans=n;LL s;
    ;i<=m;i++)
    {
        x=read(),j=,s=;
        while(s<n)
        {
            s=(LL)x*(LL)j;j++;
            if(s<=n&&!vis[s]) ans--,vis[s]=true;
        }
    }
    printf("%d",ans);
    ;
}

60分暴力

容斥原理+搜索

都会容斥原理吧,有一个数的时候为+,两个数的时候为- ,三个数的时候+、、、总的来说就是奇数的时候为+偶数的时候为-。(这不废话吗、、)

不是这些数的倍数的数的个数为总共的-每一个数的的倍数的个数+两两的倍数的个数(即为这两个数最小公倍数的倍数的个数)-每三个数的公共倍数的个数(这三个数的最小公倍数的倍数个数)、、、、

a和b最小公倍数=a*b/gcd(a,b)         ,n以内a的倍数的个数为n/a

我们用搜索判断这个数选不选,选的话数的个数+1,与原来的符号就相反,反之就相同,然后进行下一轮搜索

#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
#define N 50
#define LL long long
using namespace std;
int n,m,a[N];
long long ans;
int read()
{
    ,f=; char ch=getchar();
    ;ch=getchar();}
    +ch-',ch=getchar();
    return x*f;
}
void dfs(int f,int cnt,LL sum)
{
    if(sum>n) return ;
    )
    {
        ans+=n/sum*f;
        return ;
    }
    dfs(-f,cnt+,sum*(LL)a[cnt]/__gcd(sum,(LL)a[cnt]));
    dfs(f,cnt+,sum);
}
int main()
{
    n=read(),m=read();
    ;i<=m;i++) a[i]=read();
    dfs(,,);
    printf("%lld",ans);
    ;
}

AC代码

2.第k大区间

(kth.cpp/c/pas)

时间限制:1s

内存限制:256MB

【问题描述】

定义一个长度为奇数的区间的值为其所包含的的元素的中位数。

现给出n个数,求将所有长度为奇数的区间的值排序后,第K大的值为多少。

【输入】

输入文件名为kth.in。

第一行两个数n和k

第二行,n个数。(0<=每个数<231

【输出】

输出文件名为kth.out。

一个数表示答案。

【输入输出样例】

kth.in

kth.out

4 3

3 1 2 4

2

【样例解释】

[l,r]表示区间l~r的值

[1,1]:3

[2,2]:1

[3,3]:2

[4,4]:4

[1,3]:2

[2,4]:2

【数据说明】

对于30%的数据,1<=n<=100;

对于60%的数据,1<=n<=300

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

对于100%的数据,1<=n<=100000, k<=奇数区间的数

#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
#define N 1010
using namespace std;
int n,k,now,s,a[N],q[N*N],tmp[N];
int read()
{
    ,f=; char ch=getchar();
    ; ch=getchar();}
    +ch-',ch=getchar();
    return x*f;
}
int cmp(int a,int b){return a>b;}
int main()
{
    freopen("kth.in","r",stdin);
    freopen("kth.out","w",stdout);
    n=read(),k=read();
    ;i<=n;i++) a[i]=read();
    ;i<=n;i++)
    {
        now=;
        for(int j=i;j<=n;j++)
        {
            tmp[++now]=a[j];
            ==) continue;
            sort(tmp+,tmp++now);
            q[++s]=tmp[now/+];
        }
     }
    sort(q+,q++s,cmp);
    printf("%d",q[k]);
}

60分暴力

3. 区间求和

(sum.cpp/c/pas)

时间限制:2s

内存限制:256MB

【问题述】

有n个数,给定一个k,求所有长度大于等于k的区间中前k大数的总和。这样就比较简单相信大家都会,所以此题要求当k=1~n的总和,即求

【输入】

输入文件名为sum.in。

输入五个数n,a1,A,B,C。a1表示第一个数,A,B,C用来生成其余n-1个数。a(i)=(a(i-1)*A+B)mod C。1<=n<=1,000,000,0<=a1,A,B,C<=1,000,000,000

【输出】

输出文件名为sum.out。

一个数表示答案,最后答案对1,000,000,007取模。

【输入输出样例】

sum.in

sum.out

3 3 1 1 10

63

样例解释】

三个数为3,4,5

K=1:[1,1]=3,[1,2]=[2,2]=4,[1,3]=[2,3]=[3,3]=5

(表示各个区间在k=1时的答案)

K=2:[1,2]=7,[2,3]=[1,3]=9

K=3:[1,3]=12

【数据说明】

对于30%的数据,1<=n<=100

对于60%的数据,1<=n<=300

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

对于100%的数据,1<=n<=1000000

#include<cstdio>
#include<cstring>
#include<cstdlib>
#include<iostream>
#include<algorithm>
#define N 1010
#define mod 1000000007
#define LL long long
using namespace std;
long long ans,a[N],tmp[N];
int n,A,B,C,now;
int read()
{
    ,f=; char ch=getchar();
    ; char ch=getchar();}
    +ch-',ch=getchar();
    return x*f;
}
LL cmp(LL a,LL b){return a>b;}
int main()
{
    freopen("sum.in","r",stdin);
    freopen("sum.out","w",stdout);
    n=read(),a[]=read();
    A=read(),B=read(),C=read();
    ;i<=n;i++)
     a[i]=(a[i-]*A%C+B%C)%C;
    ;i<=n;i++)
    {
        now=;
        for(int j=i;j<=n;j++)
        {
            tmp[++now]=a[j];
            sort(tmp+,tmp++now,cmp);
            ;k<=now;k++)
             ans=(ans%mod+tmp[k]*(now-k+)%mod)%mod;
        }
    }
    printf("%lld",ans%mod);
    ;
}

60分暴力

10.1综合强化刷题 Day7的更多相关文章

  1. 10.1综合强化刷题 Day3 morning

    竞赛时间:????年??月??日??:??-??:?? 题目名称 a b c 名称 a b c 输入 a.in b.in c.in 输出 a.out b.out c.out 每个测试点时限 1s 1s ...

  2. 10.1综合强化刷题 Day3 afternoon

    竞赛时间:????年??月??日??:??-??:?? 题目名称 a b c 名称 a b c 输入 a.in b.in c.in 输出 a.out b.out c.out 每个测试点时限 1s 1s ...

  3. 10.1综合强化刷题 Day2 morning

    一道图论神题(god) Time Limit:1000ms   Memory Limit:128MB 题目描述 LYK有一张无向图G={V,E},这张无向图有n个点m条边组成.并且这是一张带权图,只有 ...

  4. 10.1综合强化刷题 Day2 afternoon

    最大值(max) Time Limit:1000ms   Memory Limit:128MB 题目描述 LYK有一本书,上面有很多有趣的OI问题.今天LYK看到了这么一道题目: 这里有一个长度为n的 ...

  5. 10.1综合强化刷题 Day1 afternoon

    一道图论好题(graph) Time Limit:1000ms   Memory Limit:128MB 题目描述 LYK有一张无向图G={V,E},这张无向图有n个点m条边组成.并且这是一张带权图, ...

  6. 10.1综合强化刷题 Day6

    T1 排序 题目描述 小Z 有一个数字序列a1; a2; .... ; an,长度为n,小Z 只有一个操作:选 定p(1<p<n),然后把ap 从序列中拿出,然后再插⼊到序列中任意位置. ...

  7. 10.1综合强化刷题 Day5

    T1 拼不出的数 lost.in/.out/.cpp[问题描述]3 个元素的集合{5; 1; 2}的所有子集的和分别是0; 1; 2; 3; 5; 6; 7; 8.发现最小的不能由该集合子集拼出的数字 ...

  8. 10.1综合强化刷题 Day4

    财富(treasure) Time Limit:1000ms   Memory Limit:128MB 题目描述 LYK有n个小伙伴.每个小伙伴有一个身高hi. 这个游戏是这样的,LYK生活的环境是以 ...

  9. 10.1综合强化刷题 Day3

    括号序列(bracket) Time Limit:1000ms   Memory Limit:128MB 题目描述 LYK有一个括号序列,但这个序列不一定合法. 一个合法的括号序列如下: ()是合法的 ...

随机推荐

  1. windows下pip安装python模块时报错【转】

    windows下pip安装python模块时报错总结 请给作者点赞--> 原文链接 1 权限问题 C:\Users\ljf>pip install xlwt Exception: Trac ...

  2. 读《深入理解jvm虚拟机》之长期存活对象进入老年代,有感!!!!

    关于这一段代码 有几个不是让人很理解的地方,我一一说来. 1.Desired survivor size 524288 bytes 关于这个512KB空间是怎么来的,JVM有这样一个参数: -XX:T ...

  3. eclipse中设置JVM内存

    一.   修改jdk 使用内存: 找到eclispe 中window->preferences->Java->Installed JRE ,点击右侧的Edit 按钮,在编辑界面中的 ...

  4. 精简Docker镜像的五种通用方法

    http://dockone.io/article/8163 精简Docker镜像的好处很多,不仅可以节省存储空间和带宽,还能减少安全隐患.优化镜像大小的手段多种多样,因服务所使用的基础开发语言不同而 ...

  5. Java集合中的细节问题

    1)集合不保存基本数据类型,而是会把基本数据类型装箱后保存. 2)Empty和null的区别:null是不存在,Empty已经初始化了,只不过里面是空的. 3)判断集合有效性: 先判断空,再判断emp ...

  6. Intellij IDEA快捷键大全

    Intellij IDEA快捷键大全 Intellij IDEA这个工具有些方面确实比较优秀,使用了一段时间的IntelliJ IDEA,感觉这个JAVA IDE非常好用!比如javascript自动 ...

  7. 【Best Time to Buy and Sell Stock III 】cpp

    题目: Say you have an array for which the ith element is the price of a given stock on day i. Design a ...

  8. 使用 SpiritManager 类管理在 XNA 游戏中的精灵(十四)

    平方已经开发了一些 Windows Phone 上的一些游戏,算不上什么技术大牛.在这里分享一下经验,仅为了和各位朋友交流经验.平方会逐步将自己编写的类上传到托管项目中,没有什么好名字,就叫 WPXN ...

  9. Mac OS使用brew安装memcached

    1.查看安装信息 brew info memcached 显示如下: memcached: stable 1.5.9 (bottled) High performance, distributed m ...

  10. Leetcode 523.连续的子数组和

    连续的子数组和 给定一个包含非负数的数组和一个目标整数 k,编写一个函数来判断该数组是否含有连续的子数组,其大小至少为 2,总和为 k 的倍数,即总和为 n*k,其中 n 也是一个整数. 示例 1: ...