A:

不细心WA了好多次

题意:给你一个a序列,再给你个b序列,你需要用b序列中的数字去替换a序列中的0,如果能够替换,则需要判断a是否能构成一个非递增的序列,a,b中所有的数字不会重复

思路:就是一步一步来,我想的可能复杂了点==。

  • 如果a中0的个数小于b的长度就No。
  • 如果a中0的个数大于等于b的长度
  1. 如果a中存在非递增就Yes,去掉0.
  2. 记录每个0前面x与后面y第一个非0的数,如果有y<x就Yes,否则如果x与y之间的0的个数>=2,不管怎么样都是Yes,否则在b中能找到一个数满足b[i]>y||b[i]<x就Yes。
  3. 以上判断的循环结束后,如果a数组末尾存在0,如果b数组的长度>=2,就Yes,否则b的长度为1 的话判断b[0]<a[n-1]就Yes
  • 除开以上情况剩下就是No

代码:

#include<stdio.h>
using namespace std;
int n,k;
int a[110];
int b[110];
int main()
{
while(~scanf("%d%d",&n,&k))
{
int cnt=0;
for(int i=0; i<n; i++)
{
scanf("%d",&a[i]);
if(a[i]==0)
cnt++;
}
for(int i=0; i<k; i++)
scanf("%d",&b[i]);
int x=-1,y=-1,z=0;
if(cnt>k)
printf("No\n");
else
{
int flag=0;
for(int i=0; i<n; i++)
{
if(a[i]>a[i+1]&&(i+1)<n&&a[i+1]!=0)
{
//printf("hhhhhhhhhhhhhhh\n");
flag=1;
break;
}
if(a[i]!=0)
y=a[i];
if(a[i]!=0&&z==0)
x=a[i];
if(a[i]==0)
z++;
if(a[i]!=0&&z>0)
{
//printf("x=%d y=%d\n",x,y);
if(x>y)
{
z=0;
flag=1;
break;
}
else if(x<y)
{
if(z>=2)
{
flag=1;
break;
}
for(int i=0; i<k; i++)
{
if(b[i]>y||b[i]<x)
{
flag=1;
break;
}
}
z=0;
break;
}
}
}
if(x==y&&x!=a[n-1]&&y!=a[n-1])
{
if(k>=2)
flag=1;
else
{
if(b[k-1]<x)
flag=1;
}
}
if(flag)
printf("Yes\n");
else
printf("No\n");
}
}
return 0;
}

B:

题意:给你两个数组,两个数组里面的值都是从1~n,并且两个数组内最多有两个数相同,两个数组之前至少有一对对应相同。要求你求得一个数组p是的a数组与b数组都是只有一个数与p对应的值不同,并且p里面色数不能重复。

思路:先预处理a,b数组,将其变为a1,a2,b1,b2。先找到a中分别相同的数,把其中一个换成没有在a中出现过的数字,得到两个新的数组a1,a2。同样b也是得到,b1,b2,然后在a1a2中找一个数组能与b1b2中的一个数组完全匹配,就直接输出这个数组就可以了。

代码:

#include<stdio.h>
#include<string.h>
using namespace std;
int n;
int a[1100];
int a1[1100];
int a2[1100];
int visa[1100];
int b[1100];
int b1[1100];
int b2[1100];
int visb[1100];
int main()
{
while(~scanf("%d",&n))
{
memset(visa,0,sizeof(visa));
memset(visb,0,sizeof(visb));
for(int i=0; i<n; i++)
{
scanf("%d",&a[i]);
visa[a[i]]++;
}
int x;
for(int i=1; i<=n; i++)
if(!visa[i])
x=i;
for(int i=0; i<n; i++)
{
scanf("%d",&b[i]);
visb[b[i]]++;
}
int y;
for(int i=1; i<=n; i++)
if(!visb[i])
y=i;
// printf("x=%d y=%d\n",x,y);
for(int i=0; i<n; i++)
{
int j;
for(j=i+1; j<n; j++)
{
if(a[i]==a[j])
break;
}
if(j==n&&visa[a[i]]!=-1)
{
a1[i]=a[i];
a2[i]=a[i];
}
else if(visa[a[i]]!=-1)
{
a1[i]=a[i];
a1[j]=x;
a2[i]=x;
a2[j]=a[i];
visa[a[i]]=-1;
}
}
for(int i=0; i<n; i++)
{
int j;
for(j=i+1; j<n; j++)
{
if(b[i]==b[j])
break;
}
if(j==n&&visb[b[i]]!=-1)
{
b1[i]=b[i];
b2[i]=b[i];
}
else if(visb[b[i]]!=-1)
{
b1[i]=b[i];
b1[j]=y;
b2[i]=y;
b2[j]=b[i];
visb[b[i]]=-1;
}
}
int c1=0,c2=0,c3=0,c4=0;
for(int i=0;i<n;i++)
{
if(a1[i]==b1[i])
c1++;
if(a1[i]==b2[i])
c2++;
if(a2[i]==b1[i])
c3++;
if(a2[i]==b2[i])
c4++;
}
if(c1==n||c2==n)
{
for(int i=0; i<n; i++)
i==n-1?printf("%d\n",a1[i]):printf("%d ",a1[i]);
}
else if(c3==n||c4==n)
{
for(int i=0; i<n; i++)
i==n-1?printf("%d\n",a2[i]):printf("%d ",a2[i]);
}

}
return 0;
}

Codeforces Round #418 (Div. 2)的更多相关文章

  1. Codeforces Round #418 (Div. 2) D. An overnight dance in discotheque

    Codeforces Round #418 (Div. 2) D. An overnight dance in discotheque 题意: 给\(n(n <= 1000)\)个圆,圆与圆之间 ...

  2. Codeforces Round #418 (Div. 2).C two points

    C. An impassioned circulation of affection time limit per test 2 seconds memory limit per test 256 m ...

  3. Codeforces Round #418 (Div. 2) B. An express train to reveries

    time limit per test 1 second memory limit per test 256 megabytes input standard input output standar ...

  4. Codeforces Round #418 (Div. 2)D

    给n个圆要么包含,要么相分离,没有两个公共点,当成一棵树,把包含的面积大的放在上面 如图最上面的par记为-1,level记为0,当par==-1||level==1时就加否则减, 就是第一,二层先加 ...

  5. Codeforces Round #418 (Div. 2) A+B+C!

    终判才知道自己失了智.本场据说是chinese专场,可是请允许我吐槽一下题意! A. An abandoned sentiment from past shabi贪心手残for循环边界写错了竟然还过了 ...

  6. Codeforces Round #418 (Div. 2) C

    Description Nadeko's birthday is approaching! As she decorated the room for the party, a long garlan ...

  7. Codeforces Round #418 (Div. 2) B

    Description Sengoku still remembers the mysterious "colourful meteoroids" she discovered w ...

  8. Codeforces Round #418 (Div. 2) A

    Description A few years ago, Hitagi encountered a giant crab, who stole the whole of her body weight ...

  9. Codeforces Round #418 (Div. 2) C. An impassioned circulation of affection

    C. An impassioned circulation of affection time limit per test 2 seconds memory limit per test 256 m ...

随机推荐

  1. 微信小程序开发——使用mock数据模拟api请求

    前言: 微信小程序开发中,后端提供了接口设计文档,前端可以先mock数据模拟api请求进行开发调试,而且可以根据需要设计mock文件的格式和内容,这样在后端接口开发完成之前,前端可以最大限度的完成前端 ...

  2. web前端面试题题目

    一.各种浏览器兼容的前缀:-o-(Opera),-ms-(IE): -moz-(火狐):-webkit-(chrome) 二.存在兼容性的css属性:placeholder,主要是因为各种浏览器pla ...

  3. Python基础 ----- 流程控制

    ------   条件判断 if 条件判判断语法: 条件判断注意: 1.由if 条件起始 2.关键字后面要加一个空格 3.条件后面接: 4.符合python代码缩进格式 5.条件判断可以有多种组合方式 ...

  4. 使用xhprof对php7程序进行性能分析

    Xhprof是facebook开源出来的一个php轻量级的性能分析工具,跟Xdebug类似,但性能开销更低,还可以用在生产环境中,也可以由程序开关来控制是否进行profile. 对于还在使用php5的 ...

  5. Mapnik 3.0.20编译安装

    1. 确定epel安装 yum install -y epel-release 2. 按照<CentOS7.2部署node-mapnik>一文中的步骤,手动安装 gcc-6.2.0 和 b ...

  6. weblogic安装升级配置

    本次操作是主要围绕如何搭建weblogic服务器升级weblogic软件及配置服务,总共有三大步骤,可划分为六个小步骤: 选取已有环境,准备weblogic压缩包,java包等 准备操作系统环境用户目 ...

  7. Hbase的基本操作(CDH组件可用)

    Habse创建一张表:    1,创建一个命名空间NameSpace(命名空间NameSpace指的是一个表的逻辑分组 ,同一分组中的各个表有类似的用途,相当于关系型数据库中的DataBase)    ...

  8. 关于PHP架构师进阶的一些思考

    相信大家都有感觉,就是当程序员写业务写了几年后,就会有想进阶的想法,技术方面当然就是架构师了,然后具体从哪些方面丰富自己才能个达到目的呢?大部分人可能会很迷茫,当然也包括我, 最近和很多大牛交流了一些 ...

  9. OO第二单元小结

    OO第二单元小结 一.三次作业代码分析. 1.第一次作业 第一次作业是单部电梯的傻瓜调度,由于其过分傻瓜,所以第一次作业我只有两个类,一个main,一个电梯,main类负责不断从输入流中读取命令,如果 ...

  10. OO第二单元多线程电梯总结

    OO第二单元多线程电梯总结 第一次作业 设计思路 Input为输入线程,负责不断读取请求并将读到的请求放入调度器中. Dispatcher为调度器,是Input线程和Elevator线程的共享对象,采 ...