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

企业名称的英文做网站名今日冯站长之家

企业名称的英文做网站名,今日冯站长之家,asp动态网页设计,外贸网上推广每日构造题训练 题目链接: 题目传送门 前置知识: 按位或运算 一、题意: 1 1 1、 有一个长度为 n n n的但是元素未知的数组 a a a, 给定 m m m个约束&#xff0c;每个约束都有 l , r , x l, r, x l,r,x, 并且满足 1 ≤ l ≤ r ≤ n , 1 ≤ x < 2 30 , a [ l ] ∣ a [ l 1 …

每日构造题训练

题目链接: 题目传送门

前置知识: 按位或运算


一、题意:

1 1 1、 有一个长度为 n n n的但是元素未知的数组 a a a, 给定 m m m个约束,每个约束都有 l , r , x l, r, x l,r,x, 并且满足 1 ≤ l ≤ r ≤ n , 1 ≤ x < 2 30 , a [ l ] ∣ a [ l + 1 ] ∣ . . . . ∣ a [ r ] = x 1 \le l \le r \le n, 1 \le x < 2^{30}, a[l] | a[l + 1] | .... | a[r] = x 1lrn,1x<230,a[l]a[l+1]∣....∣a[r]=x, l l l是按位或,要求构造出 a a a n n n个元素,使得其满足 m m m个约束并且 0 ≤ a [ i ] < 2 30 0 \le a[i] < 2^{30} 0a[i]<230,并且求出每个非空子序列(子序列可以不连续,但是要保序)的异或值之和,结果模 1 e 9 + 7 1e9+7 1e9+7, 保证在这些约束下有解。
2 2 2、数据范围: 1 ≤ n ≤ 2 e 5 1 \le n \le 2e5 1n2e5, 1 ≤ m ≤ 2 e 5 1 \le m \le 2e5 1m2e5


二、题解:

1 1 1、 我们先思考 ∣ | 运算的性质,可以知道只要在区间中有一个数字在某个二进制位上是 1 1 1,那么区间的 ∣ | 值一定在此二进制位上有 1 1 1,那么我们不妨倒着思考,假设我们知道一个区间的 ∣ | 值,我们就可以知道它们在哪些二进制一定是 0 0 0, 怎么根据这些区间记录呢,我们可以用预处理的思想去做,因为暴力去更新显然会超时。
2 2 2、我们可以开一个数组 c n t [ 30 ] [ i ] cnt[30][i] cnt[30][i]用来标记第i个数字上的第 30 30 30个二进制位,当我们读取到查询 l , r , x l,r,x l,r,x时, 我们将数字 x x x中二进制位为 0 0 0的位置找到,假设是 j j j,那么我们就可以用差分处理, c n t [ j ] [ l ] + = 1 , c n t [ j ] [ r + 1 ] − = 1 cnt[j][l] \mathrel{+}= 1, cnt[j][r + 1] \mathrel{-}= 1 cnt[j][l]+=1,cnt[j][r+1]=1,最后我们就可以用前缀和知道每个数字的每一个二进制位的信息了,此时我们不妨将每一位的初值赋值为 ( 1 < < 30 ) − 1 (1<<30)-1 (1<<30)1,这样每一个二进制位都有 1 1 1,当我们知道 c n t [ j ] [ i ] > 0 cnt[j][i]>0 cnt[j][i]>0, 则 a [ i ] & = ( 1 < < j ) a[i]\mathrel{\&}= (1<<j) a[i]&=(1<<j)
3 3 3、根据上面设计的思路我们可以找到满足约束的数组 a a a的每个元素,接下来我们要计算所有的非空子序列异或值之和,我们不妨考虑一下累积每个二进制位的贡献,我们先统计一下每个二进制位的个数 c o u n t [ i ] count[i] count[i],让我们来推导一下计算二进制位贡献的公式,首先只有奇数个 1 1 1异或值才能是 1 1 1, 所以,我们将很轻易的推导出计算贡献的公式: ∑ ( C ( 1 c o u n t [ i ] ) ∗ 2 n − 1 + C ( 3 c o u n t [ i ] ) ∗ 2 n − 3 + . . . + C ( 2 ∗ x + 1 c o u n t [ i ] ) ∗ 2 n − ( 2 ∗ x + 1 ) ) \sum(C\binom{1}{count[i]} * 2^{n-1} + C\binom{3}{count[i]} * 2^{n-3} + ... + C\binom{2 * x + 1}{count[i]}* 2^{n-(2*x+1)}) (C(count[i]1)2n1+C(count[i]3)2n3+...+C(count[i]2x+1)2n(2x+1))
4 4 4、时间复杂度(忽略常数): O ( N ∗ 30 + N ∗ l o g ( 2 30 − 1 ) ) O(N * 30 + N * log(2^{30}-1)) O(N30+Nlog(2301))


三、代码实现:

涉及算法:快速幂、组合数预处理、差分、前缀和、逆元。

#include <bits/stdc++.h>
#define int long long 
#define ff first 
#define ss second 
using namespace std; 
using PII = pair<int, int>; 
constexpr int N = 2e5 + 10; 
constexpr int inf = 0x3f3f3f3f;
constexpr int mod = 1e9 + 7; 
int n, m; 
int a[N]; 
int cnt[40][N];
int us[40]; 
int f1[N], f2[N]; 
int qmi(int x, int y) {int res = 1; while(y) {if(y & 1) res = res * x % mod; x = x * x % mod; y >>= 1; }return res; 
}int md(int a, int b) {return (f1[a] * f2[a - b] % mod * f2[b] % mod) % mod; 
}
void solve() {scanf("%lld%lld",&n,&m);// for(int j = 0; j < 40; j ++ ) us[j] = 0; for(int i = 1; i <= n; i ++ ) a[i] = (1 << 30) - 1; for(int i = 0; i < 30; i ++ ) { us[i] = 0; for(int j = 1; j <= n; j ++ ) cnt[i][j] = 0;}for(int i = 1; i <= m; i ++ ) {int l, r, x; scanf("%lld%lld%lld",&l,&r,&x);for(int j = 0; j < 30; j ++ ) {if(x >> j & 1) continue; cnt[j][l] += 1, cnt[j][r + 1] -= 1; }}for(int i = 0; i < 30; i ++ ) {for(int j = 1; j <= n; j ++ ) cnt[i][j] += cnt[i][j - 1]; for(int j = 1; j <= n; j ++ ) if(cnt[i][j]) a[j] -= (1 << i);}for(int i = 1; i <= n; i ++ ) for(int j = 0; j < 30; j ++ ) if(a[i] >> j & 1) us[j] ++; for(int i = 0; i < 30; i ++ ) {int x = us[i], su = 0;  // us[i] = 0;for(int j = 1; j <= x; j += 2) su = (su + md(x, j) * qmi(2,n-x) % mod) % mod;us[i] = su;}int ans = 0; for(int i = 0; i < 30; i ++ ) ans = (ans + (1ll << i) * us[i] % mod) % mod;printf("%lld\n",ans);    
}signed main() {f1[0] = 1, f2[0] = 1; for(int i = 1; i < N; i ++ ) {f1[i] = (f1[i - 1] * i) % mod;  f2[i] = qmi(f1[i], mod - 2);}int ts; cin >> ts; while(ts -- ) solve(); return 0; 
}
http://www.tj-hxxt.cn/news/64294.html

相关文章:

  • 客户做网站一定报价怎么办抖音推广引流平台
  • 网站域名备案主机名百度客服电话人工服务热线
  • 新疆建设工程招标网搜索引擎优化的方法与技巧
  • 个人简历模板网站静态网页设计与制作
  • 集团定制网站建设公司网站建设流程步骤
  • webstorm wordpressseo网站关键词优化
  • 网站关键词搜索优化怎么做百度客服电话人工服务热线
  • 随州网站建设哪家专业什么叫seo网络推广
  • 专做充电器的网站seo模拟点击软件
  • 工程公司有哪些优化模型的推广
  • 网站怎么做404页面今日头条新闻在线看
  • 做网站 公司百度关键词搜索排名查询
  • 怎么在网站后台做图片新闻百度文库网页版
  • 成品视频直播软件推荐哪个好一点ios现在的seo1发布页在哪里
  • 营销型网站建设的流程百度搜索高级搜索
  • 网站建设的项目计划书佛山网站建设公司哪家好
  • 微信商城开发报价关键词搜索优化外包
  • 企业办公软件排名长春网站优化团队
  • 无锡做企业网站常见网络营销推广方法
  • 如何在微信公众平台上建立微网站郑州网站优化顾问
  • 做公司网站需要花钱吗网络安全有名的培训学校
  • 在网上怎么做网站培训seo哪家学校好
  • 如何建 网站品牌推广战略
  • wordpress站下所有标签怎样创建自己的电商平台
  • 做医疗的网站seo研究中心教程
  • 网站建设的目的只是开展网络营销百度非企渠道开户
  • 做网站的 需要续费维护费吗百度云搜索引擎入口官方
  • 郴州竞价网站建设方案教育培训排行榜前十名
  • 做住宿的有几个网站排名优化方案
  • 用java怎么做游戏下载网站吗如何建立免费公司网站