[思维题]Bored Qishen
给出一个整数集,其中包含1-n的所有整数,要求挑选出一个元素最多的子集,使得子集中任意两数的乘积不是完全平方数 (n<=10^6) 
求这样一个最大子集的元素个数
#include <cstdio>
#include <cstring>
#include <cmath>
const int N = 1000006;
int b[N];
int cnt[N];
int s[N];
void init()
{
    int i, j;
    memset(b, 1, sizeof(b));
    for (i = 2; i < N; i++) {
        if (b[i]) {
            cnt[i] = i;
            for (j = i + i; j < N; j += i) {
                if(b[j]) {
                    cnt[j] = i;
                    b[j] = 0;
                } else
                    cnt[j] *= i;
            }
        }
    }
}
//法1.将范围内所有因数分解质因数,将所有含有因子不是一次的数删去
int main(int argc, char* argv[])
{
    int n, i, t;
    init();
    s[1] = 1;
    for (i = 2; i < N; i++)
    {
        if (cnt[i] == i)
            s[i] = s[i - 1] + 1;
        else
            s[i] = s[i - 1];
    }
    scanf("%d", &t);
    while (t--)
    {
        scanf("%d", &n);
        printf("%d\n", s[n]);
    }
    return 0;
}
//法2.将范围内完全平方数和完全平方数的倍数删掉
int main()
{
    int i, j;
    memset(b, 0, sizeof(b));
    for (i = 4; i < N; i++)
    {
        int sq = sqrt((double)i);
        //printf("sq = %d i = %d\n", sq, i);
        if (sq * sq == i)
            for (j = i; j < N; j += i)
                b[j] = 1;
    }
    int t, n;
    scanf("%d", &t);
    while (t--)
    {
        scanf("%d", &n);
        int ans = n;
        for (int i = 0; i <= n; i++)
            ans -= b[i];
        printf("%d\n", ans);
    }
    return 0;
}
[思维题]Bored Qishen的更多相关文章
- zoj 3778 Talented Chef(思维题)
		题目 题意:一个人可以在一分钟同时进行m道菜的一个步骤,共有n道菜,每道菜各有xi个步骤,求做完的最短时间. 思路:一道很水的思维题, 根本不需要去 考虑模拟过程 以及先做那道菜(比赛的时候就是这么考 ... 
- cf A. Inna and Pink Pony(思维题)
		题目:http://codeforces.com/contest/374/problem/A 题意:求到达边界的最小步数.. 刚开始以为是 bfs,不过数据10^6太大了,肯定不是... 一个思维题, ... 
- ZOJ 3829 贪心 思维题
		http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=3829 现场做这道题的时候,感觉是思维题.自己智商不够.不敢搞,想着队友智商 ... 
- 洛谷P4643 [国家集训队]阿狸和桃子的游戏(思维题+贪心)
		思维题,好题 把每条边的边权平分到这条边的两个顶点上,之后就是个sb贪心了 正确性证明: 如果一条边的两个顶点被一个人选了,一整条边的贡献就凑齐了 如果分别被两个人选了,一作差就抵消了,相当于谁都没有 ... 
- C. Nice Garland  Codeforces Round #535 (Div. 3) 思维题
		C. Nice Garland time limit per test 1 second memory limit per test 256 megabytes input standard inpu ... 
- PJ考试可能会用到的数学思维题选讲-自学教程-自学笔记
		PJ考试可能会用到的数学思维题选讲 by Pleiades_Antares 是学弟学妹的讲义--然后一部分题目是我弄的一部分来源于洛谷用户@ 普及组的一些数学思维题,所以可能有点菜咯别怪我 OI中的数 ... 
- UVA 1394 And Then There Was One / Gym 101415A And Then There Was One / UVAlive 3882 And Then There Was One / POJ 3517 And Then There Was One / Aizu 1275 And Then There Was One (动态规划,思维题)
		UVA 1394 And Then There Was One / Gym 101415A And Then There Was One / UVAlive 3882 And Then There W ... 
- HDU 1029 Ignatius and the Princess IV / HYSBZ(BZOJ) 2456 mode(思维题,~~排序?~~)
		HDU 1029 Ignatius and the Princess IV (思维题,排序?) Description "OK, you are not too bad, em... But ... 
- cf796c 树形,思维题
		一开始以为是个树形dp,特地去学了..结果是个思维题 /* 树结构,设最大点权值为Max,则答案必在在区间[Max,Max+2] 证明ans <= Max+2 任取一个点作为根节点,那么去掉这个 ... 
随机推荐
- URAL 1260 Nudnik Photographer(递推)
			题目链接 题意 : 给你1到n这n个数,排成一排,然后1放在左边最开始,剩下的数进行排列,要求排列出来的数列必须满足任何两个相邻的数之间的差不能超过2,问你有多少种排列 思路 : 对于dp[n], n ... 
- HDU4651+数学公式
			见Goolgle http://zh.wikipedia.org/zh-cn/%E6%95%B4%E6%95%B8%E5%88%86%E6%8B%86 /* 数学公式 ans[i]:i可以有ans[i ... 
- Android 控制ScrollView滚动到底部
			scrollView.fullScroll(ScrollView.FOCUS_DOWN);滚动到底部 scrollView.fullScroll(ScrollView.FOCUS_UP);滚动到顶部 ... 
- 【零基础学习iOS开发】【02-C语言】09-流程控制
			前言 1.默认的运行流程 默认情况下,程序的运行流程是这样的:运行程序后,系统会按书写顺序执行程序中的每一行代码.比如下面的程序 1 #include <stdio.h> 2 3 int ... 
- ANDROID_MARS学习笔记_S01_008Linear_layout例子
			1.netstone_layout.xml <?xml version="1.0" encoding="utf-8"?> <LinearLay ... 
- WPF中映射clr namspace
			1. xaml中直接映射为prefix xmlns:prefix="clr-namespace:MyApplication.Modules.Entity;assembly=MyAssembl ... 
- [POJ 2461] Billiard
			同swustoj 11 Billiard Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 1362 Accepted: 8 ... 
- POJ  3683  Priest John's Busiest Day (2-SAT,常规)
			题意: 一些人要在同一天进行婚礼,但是牧师只有1个,每一对夫妻都有一个时间范围[s , e]可供牧师选择,且起码要m分钟才主持完毕,但是要么就在 s 就开始,要么就主持到刚好 e 结束.因为人数太多了 ... 
- 声明顺序  (Bootstrap 编码规范)
			相关的属性声明应当归为一组,并按照下面的顺序排列: Positioning Box model Typographic Visual 由于定位(positioning)可以从正常的文档流中移除元素,并 ... 
- C#日期时间格式化
			日期转化一为了达到不同的显示效果有时,我们需要对时间进行转化,默认格式为:2007-01-03 14:33:34 ,要转化为其他格式,要用到DateTime.ToString的方法(String, I ... 
