J Prime Game(数学,思维,拆分素因子)

在这里插入图片描述


题意:

在这里插入图片描述


分析:

因为是相乘,所以乘得结果的素因子即是原序列各元素的素因子,那么对于任意不同的素因子,则需要求得其在所有的 fac(i, j)——对应 [i, j] 中出现的次数,或者说给最终结果贡献了多少。

样例2为例,对于素因子 '2’
包括素因子’2’ 的数6, 4, 8, 12,其对应的位置下标分别为1, 5, 9, 10

对于第1个数 ‘6’:
贡献的区间有:[1,1]、[1,2]、… … [1,10],共10个

对于第5个数 '4‘:
先考虑向左延伸并以此数结尾的区间,因为素因子2贡献的包含第1个数’6’的区间已经计算完了,即向左只能延申到第2个数’7’,所以区间为:[2,5]、[3,5]、[4,5]、[5,5],共4个
在考虑向右延伸并以此数开头的区间,那么区间为:[5,5]、[5,6]、… … [5,10],共6个
那么此数贡献的区间则为:4*6=24个

以此类推

那么对于素因子 prime[i],序列中第 j 个包含 prime[i] 的数所贡献的区间个数为
a n s [ p r i m e [ i ] ] [ j ] = ( p o s [ p r i m e [ i ] ] [ j ] − p o s [ p r i m e [ i ] ] [ j − 1 ] ) ∗ ( n − p o s [ p r i m e [ i ] ] [ j ]

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值