## Codeforces Round #738 (Div. 2) Problem (A-D1)

### A. Mocha and Math

### Topic:

There is a length of n n An integer array of n, you can choose any interval [ l , r ] [l,r] [l,r] for all i ( 0 ≤ i ≤ r − l ) i(0\le i\le r-l) i(0 < i < r_l), will a i a_i ai becomes a l + i & a r − i a_{l+i}\And a_{r-i} al+i &ar_i, which can be performed countless times.

Ask what is the minimum that the maximum value in the entire array can get.

### Solving ideas:

Actually, this seems complicated, but we all know any two numbers A & B ≤ min ( A , B ) A\And B\le \min(A,B) A&B is less than or equal to min(A,B), so no matter which interval is selected to perform the operation, it will not make the maximum value of the interval larger, so it can be compared with other numbers for each number & \And &once, so the minimum value that can be obtained for each number is the result of the sum of all numbers.

So the answer is the sum of all the integers.

### Code:

#include<bits/stdc++.h> using namespace std; const int N=110; int a[N]; int n; int main() { int T; scanf("%d",&T); while(T--){ scanf("%d",&n); for(int i=1;i<=n;i++) scanf("%d",&a[i]); int res=a[1]; for(int i=2;i<=n;i++) res&=a[i]; printf("%d\n",res); } return 0; }

### B. Mocha and Red and Blue

### Topic:

Gives a length of n n String of n, to make the entire string appear as few times as possible with the same number of adjacent characters, the string is only created by B , R , ? B,R,? B,R,?Three components, of which ？ ？ What?Indicates that this character can be specified by us as B B B and R R Either of R, outputs the final string.

### Solving ideas:

First we can only decide what is in the string ? ? What?For a sequence of characters ? ? ?,We must have chosen to construct a string with BR character spacing, so it is impossible for the next adjacent character to be the same in the middle of the string, and only possible for conflicts to occur at both ends.That's all we need to do is construct a character that's different from the one that's already defined at one end as the starting character.

If you want to prove that this greedy practice is correct, you can base your own on whether the two characters are identical and continuous ? ? What?String lengths are odd or even and can be proven in four ways, which is not repeated here.

### Code:

#include<bits/stdc++.h> using namespace std; const int N=110; char s[N]; char a[2]={'B','R'}; int n; void draw(int x,int c){ for(int i=x;i>=1;i--){ if(s[i]!='?') break; s[i]=a[c]; c^=1; } } void draw2(int x,int c){ for(int i=x,cnt=0;i<=n;i++){ if(s[i]!='?') break; s[i]=a[c]; c^=1 } } int main() { int T; scanf("%d",&T); while(T--){ scanf("%d",&n); scanf("%s",s+1); char last='R'; int p=0; for(int i=1;i<=n;i++){ if(s[i]!='?'){ draw(i-1,s[i]=='B'); last=s[i]; p=i; } } if(s[n]=='?') draw2(p+1,last=='B'); printf("%s\n",s+1); } return 0; }

### C. Mocha and Hiking

### Topic:

Exists in the diagram n + 1 n+1 n+1 point and 2 n + 1 2n +1 2n+1 directed edge.

n − 1 n-1 n_1 edge is made by i i i points to i + 1 i+1 i+1, where 1 ≤ i ≤ n − 1 1\le i\le n-1 1≤i≤n−1.

The rest n n n edges from one length to n n n Sequence a a a is given if a i = 0 a_i=0 ai = 0, then it is by i i i points to n + 1 n+1 n+1, otherwise by n + 1 n+1 n+1 points to i i i.

Ask if you can start from a point and pass through all points without missing a specific solution.

### Solving ideas:

The first reaction to the question is to think it is Euler's path, but in fact it has nothing to do with Euler's path.

Because of the first n-1 edges, we can never miss anything from 1 1 1 Walk to n n n.

So we just need to think about n + 1 n+1 n+1 This point joins the 1 1 1 to n n All for n.

- n + 1 n+1 n+1 as a starting point, just need to start from n + 1 n+1 n+1 to 1 1 1 side, that is a 1 = 1 a_1=1 a1=1.
- n + 1 n+1 Insert n+1 as the middle point i i i and i + 1 i+1 Between i+1, then all you need is i → n + 1 i\rightarrow n+1 i_n+1 and n + 1 → i + 1 n+1\rightarrow i+1 n+1_i+1, that is a i = 0 , a i + 1 = 1 a_i=0,a_{i+1}=1 ai=0,ai+1=1.
- n + 1 n+1 n+1 as the end point, only one from n n n to n + 1 n+1 n+1 edge, that is a n = 0 a_n=0 an=0.

If all three fail, there is no solution.

Time Complexity O ( n ) O(n) O(n)

### Code:

#include<bits/stdc++.h> using namespace std; const int N=1e4+10; int a[N]; int n; int main() { int T; scanf("%d",&T); while(T--){ scanf("%d",&n); for(int i=1;i<=n;i++) scanf("%d",&a[i]); if(a[1]){ printf("%d ",n+1); for(int i=1;i<=n;i++) printf("%d ",i); puts(""); } else{ int p=-1; a[n+1]=1; for(int i=1;i<=n;i++) if(!a[i]&&a[i+1]){ p=i; break; } if(p==-1) puts("-1"); else{ for(int i=1;i<=n;i++){ printf("%d ",i); if(i==p) printf("%d ",n+1); } puts(""); } } } return 0; }

### D. Mocha and Diana (Easy Version)

### Topic:

There are two reasons n n A graph with n vertices, two of which are m 1 m_1 m1 and m 2 m_2 m2 initial edges. Add the same edge to any graph while the other graph adds the same edge. Ask how many edges can be added if no rings appear in the two graphs.

1 ≤ n ≤ 1000 1\le n \le 1000 1≤n≤1000

### Solving ideas:

Because the data is small, you can maintain two unions and use them directly n 2 n^2 Violence from n2 is fine.

### Code:

#include<bits/stdc++.h> using namespace std; const int N=1010; int p1[N],p2[N]; int n,m1,m2; int find(int x,int p[]){ if(p[x]!=x) p[x]=find(p[x],p); return p[x]; } int main() { scanf("%d%d%d",&n,&m1,&m2); for(int i=1;i<=n;i++){ p1[i]=p2[i]=i; } while(m1--){ int a,b; scanf("%d%d",&a,&b); int fa=find(a,p1),fb=find(b,p1); p1[fa]=fb; } while(m2--){ int a,b; scanf("%d%d",&a,&b); int fa=find(a,p2),fb=find(b,p2); p2[fa]=fb; } vector<pair<int,int> > v; for(int i=1;i<=n;i++){ for(int j=i+1;j<=n;j++){ int pa1=find(i,p1),pb1=find(j,p1); int pa2=find(i,p2),pb2=find(j,p2); if(pa1!=pb1&&pa2!=pb2){ v.push_back({i,j}); p1[pa1]=pb1; p2[pa2]=pb2; } } } printf("%d\n",v.size()); for(auto i:v) printf("%d %d\n",i.first,i.second); return 0; }