//A
#include<bits/stdc++.h>

using namespace std;

bool vis[1000010];

void Get_Prime()
{
    int n = 1000010;
    int m = sqrt(n+0.5);
    memset(vis,0,sizeof(vis));
    for(int i=2; i<=m; i++) if(!vis[i])
        for(int j=i*i; j<=n; j+=i) vis[j] = 1;
    return ;
}

int Find(int n)
{
    for(int i=n+1; ; i++)
       if(!vis[i]) return i;
}

int main()
{
    Get_Prime();
    int t,n,x;
    long long sum;
    scanf("%d",&t);
    for(int i=1; i<=t; i++)
    {
        scanf("%d",&n);
        sum = 0;
        while(n--)
        {
            scanf("%d",&x);
            sum += Find(x);
        }
        printf("Case %d: %lld Xukha\n",i,sum);
    }
    return 0;
}
//C
#include<bits/stdc++.h>
#define MAXN 1000010

using namespace std;

bool vis[MAXN+10];
long int prime[MAXN+10];
long cnt,cnt1,cnt2;

void GetPrime()
{
    cnt = 0;
    memset(vis,0,sizeof(vis));
    for(long int i=2; i<MAXN; i++)
    {
        if(!vis[i]) prime[cnt++] = i;
        for(int j=0; j<cnt && i * prime[j] < MAXN; j++)
        {
            vis[i * prime[j]] = 1;
            if(!i%prime[j]) break;
        }
    }
    return ;
}

long long int GetY(long int n)
{
    cnt1 = 0;
    long long sum = 1;
    long m = sqrt(n);
    while(n>1 && prime[cnt1] <= m)
    {
        long cc=0;
        while(n%prime[cnt1] == 0 && n > 1)
        {
            cc++;
            n/=prime[cnt1];
        }
        sum *= cc + 1;
        cnt1++;
    }
    if(n!=1) sum *= 2;
    return sum;
}

int main()
{
    GetPrime();
    int t;
    long a,b;
    scanf("%d",&t);
    for(int j=1; j<=t; j++)
    {
        scanf("%ld %ld",&a,&b);
        if(b * b >= a)
        {
            printf("Case %d: 0\n",j);
            continue;
        }
        long long ans = GetY(a);
        ans /= 2;
        for(int i = 1; i<b; i++)
            if(a%i == 0) ans--;
        printf("Case %d: %lld\n",j,ans);
    }
    return 0;
}
//D
#include<bits/stdc++.h>

using namespace std;

int main()
{
    int t,cnt=0;
    long long n,k;
    scanf("%d",&t);
    while(t--)
    {
        scanf("%lld",&n);
        k = n;
        n -= (long long)sqrt(k);
        n -= (long long)sqrt(k/2);
        printf("Case %d: %lld\n",++cnt,n);
    }
    return 0;
}
#include<cstdio>
#include<cstdlib>
#include<cstring>

using namespace std;

const int MAXN = 3e5 + 10;
char s[50010][50];
int tree[MAXN][26];
bool flagg[MAXN];
int cnt;

void Insert(char *str)
{
    int len = strlen(str);
    int root = 0;
    for(int i=0; i<len; i++)
    {
        int id = str[i] - 'a';
        if(!tree[root][id]) tree[root][id] = ++cnt;
        root = tree[root][id];
    }
    flagg[root] = true;
    return ;
}

int Find(char *str, int n)
{
    int len = strlen(str);
    int root = 0;
    int x = 0;
    for(int i=0; i<len; i++)
    {
        int id = str[i] - 'a';
        root = tree[root][id];
        if(n!=-1 && flagg[root]==true && i<len-1)
        {
            if((x++) == n)
                return i;
        }
    }
    if(n==-1 && flagg[root] == true) return 1;
    return -1;
}

int main()
{
    char s1[25],s2[25];
    memset(tree,0,sizeof(tree));
    memset(flagg,0,sizeof(flagg));
    int j = cnt = 0;
    while(~scanf("%s",s[j]))
    {
        Insert(s[j++]);
    }
    for(int i=0; i<j; i++)
    {
        bool flag = false;
        for(int l=0; ;l++)//L表示要查找单词的第几个前缀
        {
            int d = Find(s[i],l);
            if(d == -1) break;//如果已经找不到前缀表示该单词不可能是两部分拼成的
            d = Find(&s[i][d+1],-1);//-1表示要查找的是单词的后缀部分
            if(d==1)//如果能找到相应后缀表示该单词是拼接而成
            {
                flag = true;
                break;
            }
        }
        if(flag) printf("%s\n",s[i]);
    }
    return 0;
}

VJ数论专题AC代码临时保存的更多相关文章

  1. 2.4测试赛AC代码临时保存

    //H #include<cstdio> #include<cstdlib> #include<cstring> #include<stack> usi ...

  2. 2.2测试赛AC代码临时保存

    //A #include<cstdio> #include<cstdlib> #include<algorithm> #include<cstring> ...

  3. python爬虫学习(7) —— 爬取你的AC代码

    上一篇文章中,我们介绍了python爬虫利器--requests,并且拿HDU做了小测试. 这篇文章,我们来爬取一下自己AC的代码. 1 确定ac代码对应的页面 如下图所示,我们一般情况可以通过该顺序 ...

  4. 【南阳OJ分类之语言入门】80题题目+AC代码汇总

    小技巧:本文之前由csdn自动生成了一个目录,不必下拉一个一个去找,可通过目录标题直接定位. 本文转载自本人的csdn博客,复制过来的,排版就不弄了,欢迎转载. 声明: 题目部分皆为南阳OJ题目. 代 ...

  5. HDU2449 Gauss Elimination 高斯消元 高精度 (C++ AC代码)

    原文链接https://www.cnblogs.com/zhouzhendong/p/HDU2449.html 题目传送门 - HDU2449 题意 高精度高斯消元. 输入 $n$ 个 $n$ 元方程 ...

  6. ZOJ Problem Set - 1338 Up and Down Sequences 解释 ac代码

    这道题目我一开始一头雾水,怎么都数不对,参考了下网上的博文,才弄懂. 题意是这样的,如果是上升序列,上升序列的长度不是所有上升数字的,是这么规定的,如果它与前一个数字构成上升,那么这个数字算上长度.所 ...

  7. ZOJ Problem Set - 1334 Basically Speaking ac代码及总结

    这道题目不难,是一道简单的进制转换问题,但是发现了自己两个遗漏的知识点: 1.关于scanf (1)scanf函数在输入时是以回车或者空格作为一次输入的结束 (2)scanf函数在输入字符串的过程中是 ...

  8. LeetCode OJ Symmetric Tree 判断是否为对称树(AC代码)

      思路: 主要判断左子树与右子树. 在判断左时,循环下去肯定会到达叶子结点中最左边的结点与最右边的结点比较. 到了这一步因为他们都没有左(右)子树了,所以得开始判断这两个结点的右(左)子树了. 当某 ...

  9. 【原创】用Python爬取LeetCode的AC代码到Github

    在leetCode写了105道题高调膜科,考虑搬迁到自己的GitHub上,做成一个解题题库,面试的时候也可以秀一个 但是!但是! leetCode在线IDE的功能不要太舒服,我直接线上A了不少题,本地 ...

随机推荐

  1. Eclipse安装WebJavaEE插件、Eclipse编写HTML代码(综合问题统一记录)

    1 Eclipse没有Web插件和JavaEE插件咋整 1.1 在Eclipse中菜单help选项中选择install new software选项 1.2 在work with 栏中输入 http: ...

  2. spark集群

    https://blog.csdn.net/boling_cavalry/article/details/86747258 https://www.cnblogs.com/xuliangxing/p/ ...

  3. 保存为pickle

    保存为pickle import pickle # 保存模型 with open('model.pickle', 'wb') as f: pickle.dump(model, f) # 读取模型 wi ...

  4. 吴裕雄--天生自然 R语言数据可视化绘图(4)

    par(ask=TRUE) # Basic scatterplot library(ggplot2) ggplot(data=mtcars, aes(x=wt, y=mpg)) + geom_poin ...

  5. JavaDay11

    Java learning_Day11 本人学习视频用的是马士兵的,也在这里献上 <链接:https://pan.baidu.com/s/1qKNGJNh0GgvlJnitTJGqgA> ...

  6. BundlePhobia

    1.BundlePhobia用于分析npm package的依赖.bundle后的大小.下载速度预估等等,帮助你在引用一个package之前了解引入该package的代价. 2.也可以将项目的pack ...

  7. PHP0011:学生信息管理案例

    PHP中 html js 混合用

  8. IO流学习之字符流(三)

    IO流之字符流缓冲区: 概念: 流中的缓冲区:是先把程序需要操作的数据保存在内存中,然后我们的程序读写数据的时候,不直接和持久设备之间交互,而改成和内存中的数据进行交互. 缓冲区:它就是临时存储数据, ...

  9. std::ref和std::cref使用(转载)

    转载于:https://blog.csdn.net/lmb1612977696/article/details/81543802 std::ref和std::cref 解释: std::ref 用于包 ...

  10. git三剑客笔记

    看了git三剑客视频总结的笔记,只给自己参考. 常用命令 查看分支:git branch 创建分支:git branch <name> 切换分支:git checkout <name ...