【每日一题】—— B. StORage room(Codeforces Round 912 (Div. 2))(位操作符)

2023-12-12 03:52

本文主要是介绍【每日一题】—— B. StORage room(Codeforces Round 912 (Div. 2))(位操作符),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

🌏博客主页:PH_modest的博客主页
🚩当前专栏:每日一题
💌其他专栏:
🔴 每日反刍
🟡 C++跬步积累
🟢 C语言跬步积累
🌈座右铭:广积粮,缓称王!

一.题目描述

题目大意:

塞浦路斯的天气非常炎热。因此,Theofanis 将此视为创建一家冰淇淋公司的契机。
他把冰淇淋锁在大储藏室里,防止其他冰淇淋生产商进入。然而,他忘记了密码。幸运的是,这把锁对健忘的人有特殊的功能!
要打开这把锁,你需要找到一个由 n n n 个元素组成的数组 a a a

  • KaTeX parse error: Expected 'EOF', got '&' at position 11: 0 \le a_i &̲lt; 2^{30}
  • M i , j = a i ∣ a j M_{i,j} = a_i | a_j Mi,j=aiaj 对于所有 i ≠ j i \neq j i=j ,其中 ∣ | 表示 bitwise OR 运算。
    这个锁有一个 bug,有时它会给出没有任何解的表格。在这种情况下,冰激凌将永远保持冰冻状态。
    你能找到一个数组来打开锁吗?

题目链接:

B. StORage room(Codeforces Round 912 (Div. 2))

二.思路分析

  • 首先需要知道 | 操作符的特点:只有两个数对应位上都是0时,结果的对应才是0,否则是1
  • 所以我们可以假设xi为0x7fffffff(每一位上都是1),然后用这个数与结果进行&操作,操作结束之后,就会把肯定是0的位上的1变成0(觉得难理解的可以试着用样例模拟一下)

三.代码展示

//https://codeforces.com/contest/1903/problem/B
//两个数|,如果结果的某一位为0,那么这两个数对应的位也为0
//
#include<iostream>
#include<algorithm>
#include<string>
#include<deque>
#include<map>
#include<queue>
#include<vector>
#include<cstring>
#define int long long
using namespace std;int s[2000][2000];
int v[200020];
void solve()
{memset(v,0x7fffffff,sizeof(v));int n;cin>>n;for(int i=0;i<n;i++){for(int j=0;j<n;j++){cin>>s[i][j];}}for(int i=0;i<n;i++){for(int j=0;j<i;j++){v[i]&=s[i][j];}for(int j=i+1;j<n;j++){v[i]&=s[i][j];}}int flag=1;for(int i=0;i<n;i++){for(int j=0;j<n;j++){if(i!=j&&(v[i]|v[j])!=s[i][j]){flag=0;break;}}if(flag==0){break;}}if(flag==0){cout<<"NO"<<"\n";}else if(n==1){cout<<"Yes"<<"\n";cout<<"1"<<"\n";}else{cout<<"Yes"<<"\n";for(int i=0;i<n;i++){cout<<v[i]<<" ";}cout<<"\n";}
}
signed main()
{ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);int t;cin>>t;while(t--){solve();}return 0;
}

最后:

每日一题系列旨在养成刷题的习惯,所以对代码的解释并不会特别详细,但足够引导大家写出来,选的题目都不会特别难,但也不是特别简单,比较考验大家的基础和应用能力,我希望能够将这个系列一直写下去,也希望大家能够和我一起坚持每天写代码。

之后每个星期都会不定期更新codeforces和atcoder上的题目,想要学习算法的友友们千万别错过了,有什么疑问欢迎大家在评论区留言或者私信博主!

在这里送大家一句话:广积粮,缓称王!

这篇关于【每日一题】—— B. StORage room(Codeforces Round 912 (Div. 2))(位操作符)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/483143

相关文章

Android数据库Room的实际使用过程总结

《Android数据库Room的实际使用过程总结》这篇文章主要给大家介绍了关于Android数据库Room的实际使用过程,详细介绍了如何创建实体类、数据访问对象(DAO)和数据库抽象类,需要的朋友可以... 目录前言一、Room的基本使用1.项目配置2.创建实体类(Entity)3.创建数据访问对象(DAO

Codeforces Round #240 (Div. 2) E分治算法探究1

Codeforces Round #240 (Div. 2) E  http://codeforces.com/contest/415/problem/E 2^n个数,每次操作将其分成2^q份,对于每一份内部的数进行翻转(逆序),每次操作完后输出操作后新序列的逆序对数。 图一:  划分子问题。 图二: 分而治之,=>  合并 。 图三: 回溯:

Codeforces Round #261 (Div. 2)小记

A  XX注意最后输出满足条件,我也不知道为什么写的这么长。 #define X first#define Y secondvector<pair<int , int> > a ;int can(pair<int , int> c){return -1000 <= c.X && c.X <= 1000&& -1000 <= c.Y && c.Y <= 1000 ;}int m

Codeforces Beta Round #47 C凸包 (最终写法)

题意慢慢看。 typedef long long LL ;int cmp(double x){if(fabs(x) < 1e-8) return 0 ;return x > 0 ? 1 : -1 ;}struct point{double x , y ;point(){}point(double _x , double _y):x(_x) , y(_y){}point op

Codeforces Round #113 (Div. 2) B 判断多边形是否在凸包内

题目点击打开链接 凸多边形A, 多边形B, 判断B是否严格在A内。  注意AB有重点 。  将A,B上的点合在一起求凸包,如果凸包上的点是B的某个点,则B肯定不在A内。 或者说B上的某点在凸包的边上则也说明B不严格在A里面。 这个处理有个巧妙的方法,只需在求凸包的时候, <=  改成< 也就是说凸包一条边上的所有点都重复点都记录在凸包里面了。 另外不能去重点。 int

C++操作符重载实例(独立函数)

C++操作符重载实例,我们把坐标值CVector的加法进行重载,计算c3=c1+c2时,也就是计算x3=x1+x2,y3=y1+y2,今天我们以独立函数的方式重载操作符+(加号),以下是C++代码: c1802.cpp源代码: D:\YcjWork\CppTour>vim c1802.cpp #include <iostream>using namespace std;/*** 以独立函数

Codeforces 482B 线段树

求是否存在这样的n个数; m次操作,每次操作就是三个数 l ,r,val          a[l] & a[l+1] &......&a[r] = val 就是区间l---r上的与的值为val 。 也就是意味着区间[L , R] 每个数要执行 | val 操作  最后判断  a[l] & a[l+1] &......&a[r] 是否= val import ja

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟)

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟) 题目描述 给定一个链表,链表中的每个节点代表一个整数。链表中的整数由 0 分隔开,表示不同的区间。链表的开始和结束节点的值都为 0。任务是将每两个相邻的 0 之间的所有节点合并成一个节点,新节点的值为原区间内所有节点值的和。合并后,需要移除所有的 0,并返回修改后的链表头节点。 思路分析 初始化:创建一个虚拟头节点

每日一题|牛客竞赛|四舍五入|字符串+贪心+模拟

每日一题|四舍五入 四舍五入 心有猛虎,细嗅蔷薇。你好朋友,这里是锅巴的C\C++学习笔记,常言道,不积跬步无以至千里,希望有朝一日我们积累的滴水可以击穿顽石。 四舍五入 题目: 牛牛发明了一种新的四舍五入应用于整数,对个位四舍五入,规则如下 12345->12350 12399->12400 输入描述: 输入一个整数n(0<=n<=109 ) 输出描述: 输出一个整数

每日一练7:简写单词(含链接)

1.链接 简写单词_牛客题霸_牛客网 2.题目 3.代码1(错误经验) #include <iostream>#include <string>using namespace std;int main() {string s;string ret;int count = 0;while(cin >> s)for(auto a : s){if(count == 0){if( a <=