当前位置: 首页 > news >正文

传奇辅助网站怎么建设电商app软件

传奇辅助网站怎么建设,电商app软件,wordpress模板程序,服务器登录入口洛谷 NOIP 2023 模拟赛 P9836 种树 文章目录 洛谷 NOIP 2023 模拟赛 P9836 种树题目大意思路code 题目大意 路边有 n n n 棵树,每棵树的 高度 均为正整数,记作 p 1 , p 2 … p n p_1, p_2 \dots p_n p1​,p2​…pn​。 定义一棵树的 宽度 为它高度的…

洛谷 NOIP 2023 模拟赛 P9836 种树

文章目录

  • 洛谷 NOIP 2023 模拟赛 P9836 种树
    • 题目大意
    • 思路
    • code

题目大意

路边有 n n n 棵树,每棵树的 高度 均为正整数,记作 p 1 , p 2 … p n p_1, p_2 \dots p_n p1,p2pn

定义一棵树的 宽度 为它高度的正因数个数,这些树能覆盖的距离为它们宽度的乘积,你想请你的朋友们来乘凉,但你发现这些树能覆盖的距离不够多。

于是你买了总量为 w w w 单位的神奇化肥。你可以施若干次肥,每次你可以使用 k k k 单位化肥(要求 k k k 必须为当前化肥量的正因数),让任意一棵树的高度乘上 k k k,同时你剩余的化肥量也会除以 k k k。每次施肥的树可任意选择,且每次施肥选择的树不需相同。

你需要最大化这些树所能覆盖的距离,并输出这个最大距离。答案对 998244353 998244353 998244353 取模。

n , p , w ≤ 1 0 4 n , p , w \le 10^4 n,p,w104

思路

我们把 a i a_i ai 进行质因数分解: a i = p 1 b 1 ∗ p 2 b 2 ⋯ a_i = p_1^{b_1} * p_2^{b_2}\cdots ai=p1b1p2b2

那么这棵树的宽度就是 ( b 1 + 1 ) ∗ ( b 2 + 1 ) ⋯ (b_1 + 1) * (b_2+1) \cdots (b1+1)(b2+1)

那么答案就是把所有的 a a a 进行质因数分解然后把每个质数的总数加一,然后乘起来。

对于 w w w ,我们也把它质因数分解: w = p 1 b 1 ∗ p 2 b 2 ⋯ w = p_1^{b_1} * p_2^{b_2}\cdots w=p1b1p2b2,然后把每个 p p p 都分到包含这个质数最小的数上,这个可以用一个对来维护。

code

#include <bits/stdc++.h>
#define LL long long
#define fu(x , y , z) for(int x = y ; x <= z ; x ++)
using namespace std;
const int N = 1e4 + 5;
const LL mod = 998244353;
int n , w , vis[N + 5] , b[N + 5] , b1 , ans1[N][2005];
long long p[N];
struct node {int id , v;bool operator > (const node &t) const {return v > t.v;}
} ;
priority_queue<node , vector<node> , greater<node>> q;
int main () {// freopen ("plant.in" , "r" , stdin);int a;scanf ("%d%d" , &n , &w);fu (i , 1 , n) scanf ("%lld" , &p[i]);int w1 = sqrt (w);int a1;node now;LL ans = 1;fu (i , 2 , N) {if (!vis[i]) b[++b1] = i;fu (j , 1 , b1) {if (i * b[j] > N) break;vis[i * b[j]] = 1;if (i % b[j] == 0) break;}}// fu (i , 1 , 10) cout << b[i] << " ";// return 0;fu (i , 1 , b1) {a = 0;while (w % b[i] == 0) {w /= b[i];a ++;}fu (j , 1 , n) {a1 = 0;while (p[j] % b[i] == 0) {a1 ++;p[j] /= b[i];}q.push((node){j , a1 + 1});}while (a --) {now = q.top();q.pop();now.v ++;q.push(now);}while (!q.empty()) {now = q.top();q.pop();ans = ans * 1ll * now.v % mod;}}printf ("%lld" , ans);return 0;
}
http://www.yayakq.cn/news/864343/

相关文章:

  • 苏州做网站哪家好360兼容模式网站错位
  • 农业产品如何建网站做优惠券网站
  • 做微课的网站有哪些方面全flash网站欣赏
  • 建设多语种网站如何做教育类网站
  • 做网站原型现成的框架wordpress 网银
  • 浙江省建设投资集团有限公司网站安徽网站优化怎么做
  • 关于动漫网站建设规划表精美大气的餐饮类企业网站
  • 四川响应式网站哪家好中铁建设集团有限公司总承包公司
  • 上海专业网站制作设计公司哪家好爱站网收录
  • 网站建设提升界面流畅程度微信小程序网站建设公司
  • 上海 网站建设google做下载网站好不好做
  • 网站建设需要的技术住房和城乡建设部网站造价
  • 做母婴网站网站首页被降权
  • 内蒙古建设工程造价信息网官方网站万网 网站托管
  • 石家庄建设局官方网站263企业邮箱官方入口
  • 晋城市公共事业建设局网站个人网站建设 毕业设计
  • 校园二手网站设计论文销售系统管理软件免费
  • 好网站目录如何进行软件开发
  • 长治哪里做网站泰州模板建站源码
  • 哪个网站可以免费做H5网站开发不满意
  • 大连p2p网站建设建设银行信用卡网站
  • 建设部网站官网考试wordpress主题字体用隶书
  • 旅游网站技术方案大连工业大学艺术与信息工程学院
  • 烟台专业网站建设wordpress 列表
  • php零基础做网站深圳住建局官方网电话
  • 青岛网站制作seo找图纸的网站
  • 佛山网站建设开发团队电商网站开发要多少钱
  • 做网站是怎么赚钱做企业网站一般多少钱
  • 兰州网站哪里做阿里云域名怎么做网站
  • html网站优化重庆百度快照优化