CF576A Vasya and Petya's Game

数论思维题。

根据唯一分解定理,可以知道,如果一个数的各个质因数数量确定了,这个数也就确定了。

每次询问的中,如果 \(x\) 是 \(y\) 的倍数,证明 \(x\) 中含 \(y\) 的所有质因数。我们可以枚举质数,判定 \(x\) 能否整除这个质数,就可以判断 \(x\) 是否含有这个质因数。

但是这还不能完全确定 \(x\),因为这样只能确定是否有某个质因数,而不能确定质因数的数量。为了确定质因数的数量,我们可以把这个质数(设 \(a\) 为这个质数)的 \(b\) 次方都枚举一遍,同时保证 \(a^b\le n\)。因为由乘方的定义,得 \(a^b\) 中含有 \(b\) 个 \(a\),如果 \(x\) 是 \(a^b\) 的倍数,证明 \(x\) 中至少含有 \(b\) 个质因数 \(a\)。把 \(\le n\) 的这类数字都枚举一遍,就可以确定 \(x\) 各个质因子的个数了。

所以,我们先用线性筛筛出 \(\le n\) 的质数,然后根据上文所述计算输出即可。

完整代码

#include <bits/stdc++.h>
using namespace std;
int n,pri[70000],ansd[10000];
bool a[700000];
int linear(bool a[],int pri[],int n)
{
int cnt=0;
a[1]=1;
for(int i=2;i<=n;i++)
{
if(!a[i])pri[cnt++]=i;
for(int j=0;j<cnt&&i*pri[j]<=n;j++)
{
if(!a[i*pri[j]])a[i*pri[j]]=1;
if(i%pri[j]==0)break;
}
}
return cnt;
} int main()
{
int ans=0;
scanf("%d",&n);
int cnt=linear(a,pri,n);
for(int i=0;i<cnt;i++)
{
int now=1;
while(now*pri[i]<=n)now*=pri[i],ansd[ans++]=now;
}
printf("%d\n",ans);
for(int i=0;i<ans;i++)
printf("%d ",ansd[i]);
return 0;
}

AC记录

CF576A Vasya and Petyas Game 题解的更多相关文章

  1. CF576A Vasya and Petya's Game

    题目大意: 给定一个数字 n,现在 Vasya 要从 1∼n 中想一个数字 x. Petya 向 Vasya 询问 "x 是否能整除 y?" ,通过 Vasya 的回答来判断 x ...

  2. CF355B Vasya and Public Transport 题解

    Content 小 \(A\) 要乘坐交通工具,其中公交车的辆数是 \(n\),第 \(i\) 辆公交车的编号为 \(i\),乘坐次数为 \(a_i\):手推车的辆数是 \(m\),每辆手推车的编号为 ...

  3. CF1042E Vasya and Magic Matrix 题解

    题目链接 思路分析 看到题目中 \(n,m \leq 1000\) ,故直接考虑 \(O(n^2)\) 级别做法. 我们先把所有的点按照 \(val\) 值从小到大排序,这样的话二维问题变成序列问题. ...

  4. CF493A Vasya and Football 题解

    Content 有两个球队在踢足球,现在给出一些足球运动员被黄牌或红牌警告的时间,求每个队员第一次被红牌警告的时间. 注意:根据足球比赛规则,两张黄牌自动换成一张红牌. 数据范围:比赛时间 \(90\ ...

  5. CF1082A Vasya and Book 题解

    Content 给定 \(T\) 组数据,每组数据给出四个整数 \(n,x,y,d\).小 V 有一本 \(n\) 页的书,每次可以恰好翻 \(d\) 页,求从第 \(x\) 页恰好翻到第 \(y\) ...

  6. CF1036D Vasya and Arrays 题解

    Content 给定两个长度分别为 \(n\) 和 \(m\) 的数列 \(A,B\).你需要将两个数列都恰好分成 \(k\) 份,使得两个数列中第 \(i(i\in[1,k])\) 份的元素和对应相 ...

  7. CF1065A Vasya and Chocolate 题解

    Content 小 V 有 \(s\) 块钱,商店里有巧克力卖,每块巧克力 \(c\) 块钱,现在商店给出优惠:购买 \(a\) 块巧克力可以免费获得 \(b\) 块巧克力,求小 V 最多能够买到的巧 ...

  8. Codeforces Round #324 (Div. 2) C. Marina and Vasya 贪心

    C. Marina and Vasya Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/584/pr ...

  9. Codeforces Round #322 (Div. 2) A. Vasya the Hipster 水题

    A. Vasya the Hipster Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/581/p ...

  10. Codeforces Codeforces Round #319 (Div. 2) C. Vasya and Petya's Game 数学

    C. Vasya and Petya's Game Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/ ...

随机推荐

  1. 一款让 Everything 更加如虎添翼的 .NET 开源辅助工具!

    前言 相信很多同学都应该用过 Everything 这个实用的 Windows 文件搜索神器吧,今天大姚给大家分享一款让 Everything 更加如虎添翼的 .NET 开源辅助工具:Everythi ...

  2. 基于transformer的机器翻译:手把手教你实现

    目录 前言 transformer模型的搭建 Input embedding Encoder Decoder output transformer构建 data数据集处理 train config 参 ...

  3. 打造企业级AI文案助手:GPT-J+Flask全栈开发实战

    一.智能文案革命的序幕:为什么需要AI文案助手? 在数字化营销时代,内容生产效率成为企业核心竞争力.据统计,营销人员平均每天需要撰写3.2篇文案,而传统人工创作存在三大痛点: 效率瓶颈:创意构思到成文 ...

  4. XXL-TOOL v1.4.0 发布 | Java工具类库

    Release Notes 1.[新增]JsonRpc模块:一个轻量级.跨语言远程过程调用实现,基于json.http实现(从XXL-JOB底层通讯组件提炼抽象). 2.[新增]Concurrent模 ...

  5. Python基础 - 多进程(下)

    上篇主要对多任务从生活上来认识, 同时引入对 进程 的认识, 即操作系统资源分配的基本单元. 然后通过对 并发, 并行 概念的认识, 去理解 任务调度. 然后用内置的 multiprocessing ...

  6. 实战研究:提升Web应用的安全性

    @charset "UTF-8"; .markdown-body { line-height: 1.75; font-weight: 400; font-size: 15px; o ...

  7. [python] 轻量级定时任务调度库schedule使用指北

    schedule是一款专为简化定时任务调度而设计的Python库,它通过直观的语法降低了周期性任务的实现门槛.作为进程内调度器,它无需额外守护进程,轻量且无外部依赖,适合快速搭建自动化任务.不过,该库 ...

  8. 服务器操作SCP命令使用

    一.将本地代码上传服务器scp命令操作 命令是:scp dtcloud-master.zip root@10.14.22.141:/opt/dtcloud/ 将本地的scp dtcloud-maste ...

  9. TUF系统概述

    TUF基本介绍 TUF 是一个为软件更新系统设计的安全框架,最初由纽约大学的 Secure Systems Lab 提出.它的目标是解决传统软件更新过程中的各种安全问题(如中间人攻击.回滚攻击.密钥泄 ...

  10. Ceph性能测试

    一.测试分类 ceph的性能测试包含rados性能测试和rbd性能测试 二.测试工具 rados性能测试工具:使用ceph自带的rados bench工具.rados losd-gen工具 rbd性能 ...