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

企业名称的英文做网站名it培训班

企业名称的英文做网站名,it培训班,做图模板网站有哪些内容,成都app制作公司每日构造题训练 题目链接: 题目传送门 前置知识: 按位或运算 一、题意: 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.yidumall.com/news/69679.html

相关文章:

  • 做网站工资高吗企业网站建站模板
  • 用.cc做网站官网可以吗谷歌关键词分析工具
  • 织梦做的网站打开慢怎样在百度上发布广告
  • wordpress 自定义简码无锡百度快速优化排名
  • 福田住房和建设局官网seo提供服务
  • 网站运营部门职责给大家科普一下b站推广网站
  • 北京顺义做网站重庆seo整站优化设置
  • 做网站定位搜索词排行榜
  • linux做网站网络课堂智能建站abc
  • 建设网站哪家最好线上推广员是做什么的
  • 在国内做博彩网站代理国内重大新闻10条
  • 专做网页的网站百度推广售后电话
  • 建站公司网站模板网络运营培训课程
  • 电商网站开发价格河北seo推广公司
  • 广州白云网站建设网站seo运营
  • 个人或主题网站建设实验体会怎么找百度客服
  • 网站优化的前景网络营销成功案例ppt
  • html5 企业 网站百度上做推广怎么收费
  • 青岛做网站的公司排名百度知道合伙人答题兼职
  • 如何把网站做的好看seo的中文含义
  • 客户管理系统admin宁波关键词优化品牌
  • 扁平化风格 网站网络快速排名优化方法
  • 在哪个网站上找超市做生鲜如何快速推广自己的网站
  • 精品课程网站设计新乡seo外包
  • 做进口零食批发网站推广公众号的9种方法
  • wordpress主题手机版seo代码优化
  • 腾讯企业邮箱免费网页seo搜索引擎优化
  • 如何做后台网站增删改seo优化便宜
  • 购物网站做兼职李勇seo的博客
  • 猪八戒 网站开发支付网络项目发布网