2020.04.29【NOIP普及組】シミュレーションC組30
31582 ワード
リンク
T1:
三重爆発力1:芝生数2:可能数3:乳牛数
T2:
プラスとマイナスの大小の問題です詳しくはコードを参照してください
T3:
サイクルを特定
T4:
同じものを並べてxからyまで調べると、彼らが同じかどうかを見て、同じであれば途中でzを通っていないことを示します.
T1:
三重爆発力1:芝生数2:可能数3:乳牛数
#include
#include
using namespace std;
int m,n,j,a[10010],b[10010],f[10010];
int main(){
freopen("revegetate.in","r",stdin);
freopen("revegetate.out","w",stdout);
cin>>n>>m;
for(int i=1;i<=m;i++){
cin>>a[i]>>b[i];
if(a[i]>b[i]){
int sw=a[i];
a[i]=b[i];
b[i]=sw;
}
}
for(int i=1;i<=n;i++){
for(j=1;j<=4;j++){
bool flag=0;
for(int k=1;k<=m;k++){
if(b[k]==i&&f[a[k]]==j){
flag=1;
}
}
if(flag==0)break;
}
f[i]=j;
}
for(int i=1;i<=n;i++)cout<<f[i];
return 0;
}
T2:
プラスとマイナスの大小の問題です詳しくはコードを参照してください
#include
#include
#include
#include
using namespace std;
int m,n;
struct node{
string f;
int x,y;
}a[1001000];
int main(){
freopen("traffic.in","r",stdin);
freopen("traffic.out","w",stdout);
int l=0,r=1000100;
cin>>n;
for(int i=1;i<=n;i++){
cin>>a[i].f>>a[i].x>>a[i].y;
if(a[i].f=="none"){
l=max(l,a[i].x);
r=min(r,a[i].y);
}// 1~3,2~4, 2~3
if(a[i].f=="on"){
l+=a[i].x;
r+=a[i].y;
}//
if(a[i].f=="off"){
l-=a[i].y;
r-=a[i].x;
}
l=max(l,0);
}
int l1=0,r1=1000010;
for(int i=n;i>=1;i--){
if(a[i].f=="none"){
l1=max(l1,a[i].x);
r1=min(r1,a[i].y);
}
if(a[i].f=="on"){
l1-=a[i].y;
r1-=a[i].x;
}
if(a[i].f=="off"){
l1+=a[i].x;
r1+=a[i].y;
}
l1=max(l1,0);
}
cout<<l1<<' '<<r1<<endl<<l<<' '<<r;
return 0;
}
T3:
サイクルを特定
#include
#include
using namespace std;
int a[9]={0,1,2,4,7,8,11,13,14};
int n;
int main(){
freopen("moobuzz.in","r",stdin);
freopen("moobuzz.out","w",stdout);
cin>>n;
int m=n/8;
int k=n%8;
if(k==0)cout<<m*15-1;
else cout<<m*15+a[k];
return 0;
}
T4:
同じものを並べてxからyまで調べると、彼らが同じかどうかを見て、同じであれば途中でzを通っていないことを示します.
#include
#include
using namespace std;
int m,n,fa[100100],a[100100];
char c[100100];
int getf(int x){
if(fa[x]==x)return x;
else return fa[x]=getf(fa[x]);
}
int main(){
freopen("milkvisits.in","r",stdin);
freopen("milkvisits.out","w",stdout);
cin>>n>>m;
for(int i=1;i<=n;i++){
cin>>c[i];
fa[i]=i;
}
for(int i=1;i<=n-1;i++){
int x,y;
cin>>x>>y;
if(c[x]==c[y]){
int x1=getf(x);
int y1=getf(y);
fa[x1]=y1;
}
}
for(int i=1;i<=m;i++){
int x,y;
char c1;
cin>>x>>y>>c1;
if(getf(x)==getf(y)&&c[x]!=c1)a[i]=0;
else a[i]=1;
}
for(int i=1;i<=m;i++)cout<<a[i];
return 0;
}