20181028(水题+二分图(?)+暴力(?))

Jingle
(jingle.pas/c/cpp)
【问题描述】
在他的老师约翰·塞巴斯蒂安三世的指导下,小H 已经开始了他在音乐方面的才能并开
始尝试写一些曲子。曲子分为若干个单元,每个单元由“/”隔开,如下面这首曲子:
/HH/QQQQ/XXXTXTEQH/W/HW/
当然,其中的大写字母分别代表着一些音符
(Duration 表示音符的节拍长度,Identifier 表示音符的缩写,Notes 表示音符)
在小H 的老师约翰·塞巴斯蒂安三世看来,只有节拍长度之和是1 的单元才是完美的,现在
小H 写了一些曲子,他希望你能给出他曲子的有多少个单元是完美的。
【输入格式】
一行字符串,由表格中的大写字母和/组成。保证合法。
【输出格式】
一个数字,完美单元的个数。
【输入输出样例】
in
/HH/QQQQ/XXXTXTEQH/W/HW/
out
4
【样例解释】
/HH/QQQQ/XXXTXTEQH/W
全国信息学奥林匹克联赛(NOIP2016)复赛模拟 提高组第一试
第 3 页 共 5 页
Perfect
(perfect.pas/c/cpp)
问题描述
给定M 个二元组(A_i, B_i),求X_1, …, X_N 满足:对于任意(A_i, B_i),有|X_{A_i}

  • X_{B_i}| = 1 成立。
    输入
    第1 行,2 个整数N、M。
    第2 行到第M + 1 行,2 个整数A_i 和B_i。
    输出
    第1 行,1 个字符串,"YES"表示有解,"NO"表示无解。
    第2 行,N 个整数,X_1, X_2, …, X_N,无解则不输出。
    要求|X_i| <= 1,000,000,000,任意一解均可。
    样例
    in
    3 3
    1 2
    2 3
    3 1
    out
    NO
    in
    6 5
    1 2
    2 3
    3 4
    4 1
    5 6
    out
    YES
    0 1 0 1 -99 -100
    数据范围
    对于40%的数据,1 <= N <= 10。
    对于100%的数据,1 <= N <= 10,000,0 <= M <= 100,000,1 <= A_i, B_i <= N。
    全国信息学奥林匹克联赛(NOIP2016)复赛模拟 提高组第一试
    第 4 页 共 5 页
    Pair
    (pair.pas/c/cpp)
    【问题描述】
    流行的跳棋游戏是在一个有mn个方格的长方形棋盘上玩的。棋盘起初全部被动物或障碍物占满了。在一个方格中,‘X’表示一个障碍物,一个‘0’~‘9’的个位数字表示一个不同种类的动物,相同的个位数字表示相同种类的动物。一对动物只有当它们属于同一种类时才可以被消去。消去之后,他们所占的方格就成为空方格,直到游戏结束。要消去一对动物的前提条件是:这对候选动物所在的方格必须相邻,或它们之间存在一条通路。棋盘上一个方格只和其上下左右的方格相邻。一条通路是由一串相邻的空方格组成。路的长度则是通路中空方格的数目。你要输出可被消去的动物的最多对数,以及在此操作过程中,最小的通路长度总和。
    例1
    如下的一个3
    4棋盘:
    两个种类为“1”的动物可以被消去,因为它们相邻,通路的长度是0。在这一步骤之后,存在一条在两个种类为“0”的动物间的长度为2的通路,所以这两个动物也可以被消去。要消去这2对动物,通路的长度总和是 0+2=2。这也是最小的通路长度总和,因为这是唯一一个消去这2对动物的方法。所以答案是 2 2。
    例2
    如下的一个4*1棋盘:
    如果我们先消去正中间的两个种类为“9”的动物,然后消去最上面和最下面的两个种类为“9”的动物,则累计通路长度为 0+2=2。但是,我们可以先消去最顶上的两个,然后再消去最底下的两个。同样也消去了2对动物,但通路长度总和是 0+0=0。很明显,长为0的通路长度总和是最短的,答案应是 2 0。
    【输入格式】
    输入文件第一行包含二个整数 m和n,中间用一个空格隔开,其中1<=m,n<=5。接下来的m行,每一行有n个字符,每个字符是’X’,‘0’,‘1’,…,'9’其中的一个。相邻两个字符间没有空格。
    【输出格式】
    全国信息学奥林匹克联赛(NOIP2016)复赛模拟 提高组第一试
    第 5 页 共 5 页
    输出文件仅有一行包含两个整数,中间用一个空格隔开。第一个整数是可被消去的动物的最多对数。第二个整数是消去这些动物对的过程中,最小的通路长度总和。
    【输入输出样例一】in
    3 4
    XX0X
    X11X
    X0XX
    out
    2 2
    【数据范围】
    N,M<=5

T1
题意概括:每个字符表示一个值,求字符串的总值加起来等于1的‘

#include<bits/stdc++.h>
using namespace std;

int a[128],n,m;
string s;

int main()
{
	cin>>s;
	a['W']=64; a['H']=32;
	a['Q']=16; a['E']=8;
	a['S']=4;  a['T']=2; a['X']=1;
    int len=s.size()-1;
    int i=0,ans=0;;
    while (i<=len)
      {
      	if (s[i]=='/') i++;
      	int num=0;
      	while (s[i]!='/'&&i<=len) 
      	  {
      	  	num+=a[s[i]];
      	  	i++;
      	  }
      	//cout<<num<<endl;
      	if (num==64) ans++;
      }
    printf("%d",ans);
	
}

T2
题意概括:看给的这些点能否构成二分图,能输出方案,不能输出NO

暴力dfs,记一下奇偶步数,如果一个点多次遇到,且奇偶步不一样,那么久NO,否则01染色之
出解


#include<bits/stdc++.h>
using namespace std;
const int maxn=10010;
const int maxm=100010;
int head[maxn],n,m,cnt,vis[maxn],ans[maxn],ansnum[maxn];
bool p;
struct node
{
	int v,nxt,w;
} e[maxm<<1];
inline void add(int u,int v)
{
	cnt++;
	e[cnt].nxt=head[u];
	e[cnt].v=v;
	head[u]=cnt;
}
inline void dfs(int u,int fa)
{
	for (int i=head[u]; i; i=e[i].nxt)
	  {
	  	int v=e[i].v;
	  	if (v==fa) continue;
	  	if (vis[v])
	  	  {
	  	  	if ((ans[u]%2)==(ans[v]%2)) {cout<<"NO"; exit (0);}
	  	  	continue;
	  	  }
	  	ans[v]=ans[u]+1;
	  	ansnum[v]=ansnum[u]^1;
	  	vis[v]=1;
	  	dfs(v,u);
	  }
}
int main()
{ 
	scanf("%d%d",&n,&m);
	for (int i=1; i<=m; i++)
	  {
	  	int x,y;
	  	scanf("%d%d",&x,&y);
	  	add(x,y);
	  	add(y,x);
	  }
    p=true;
    ansnum[0]=1;
	for (int i=1; i<=n; i++)
	  if (vis[i]==0)
       {
	    	vis[i]=1;
	    	dfs(i,0);
	    }
	if (p)
	{
	    printf("YES\n");
	  	for (int i=1;i<=n; i++)
	  	  printf("%d ",ansnum[i]);
	}
	else
		printf("NO");
}

T3
题意概括:……题目说的很清楚了
暴力(?)( N &lt; = 5 , M &lt; = 5 N&lt;=5,M&lt;=5 N<=5,M<=5

#include<bits/stdc++.h>
#pragma GCC optimize(2)
#define R(i,s,t) for(int i=s;i<=t;i++)
#define GN(x,y) ((x)*m+(y))
using namespace std;
typedef pair<int,int> pii;
int n,m,ans,low;
char s[6][6];
void update(int p,int l) {
    if(p>ans) {ans=p; low=l;}
    else if(p==ans) low=min(low,l);
}
int cnt,vis[34000000];
void dfs(int p,int l,int state) {
    if(++cnt>2e6) {cout<<ans<<' '<<low<<endl;exit(0);}
    if(vis[state]<=l) return;
    vis[state]=l;
    update(p,l);
    R(i,0,n-1) R(j,0,m-1) if(isdigit(s[i][j])) {
        char rec=s[i][j];
        queue<pii> q;
        q.push(make_pair(GN(i,j),0));
        bool vis[5][5]; memset(vis,0,sizeof vis);
        while(!q.empty()) {
            int cur=q.front().first,step=q.front().second;
            q.pop(); int r=cur/m,c=cur%m,rc=GN(i,j);
            if(c>0) {
                if(s[r][c-1]==s[i][j]&&(r!=i||c-1!=j)) {
                    s[r][c-1]=s[i][j]='*';
                    dfs(p+1,l+step,state|1<<rc|1<<GN(r,c-1));
                    s[r][c-1]=s[i][j]=rec;
                }
                if(s[r][c-1]=='*'&&!vis[r][c-1])
                    {vis[r][c-1]=true; q.push(make_pair(GN(r,c-1),step+1));}
            }
            if(c<m-1) {
                if(s[r][c+1]==s[i][j]&&(r!=i||c+1!=j)) {
                    s[r][c+1]=s[i][j]='*';
                    dfs(p+1,l+step,state|1<<rc|1<<GN(r,c+1));
                    s[r][c+1]=s[i][j]=rec;
                }
                if(s[r][c+1]=='*'&&!vis[r][c+1])
                {vis[r][c+1]=true; q.push(make_pair(GN(r,c+1),step+1));}
            }
            if(r>0) {
                if(s[r-1][c]==s[i][j]&&(r-1!=i||c!=j)) {
                    s[r-1][c]=s[i][j]='*';
                    dfs(p+1,l+step,state|1<<rc|1<<GN(r-1,c));
                    s[r-1][c]=s[i][j]=rec;
                }
                if(s[r-1][c]=='*'&&!vis[r-1][c])
                {vis[r-1][c]=true; q.push(make_pair(GN(r-1,c),step+1));}
            }
            if(r<n-1) {
                if(s[r+1][c]==s[i][j]&&(r+1!=i||c!=j)) {
                    s[r+1][c]=s[i][j]='*';
                    dfs(p+1,l+step,state|1<<rc|1<<GN(r+1,c));
                    s[r+1][c]=s[i][j]=rec;
                }
                if(s[r+1][c]=='*'&&!vis[r+1][c])
                {vis[r+1][c]=true; q.push(make_pair(GN(r+1,c),step+1));}
            }
        }
    }
}
int main() {
#ifdef LOCAL 
    freopen("pair.in","r",stdin);
#endif
    cin>>n>>m;
    R(i,0,n-1) cin>>s[i];
    memset(vis,0x3f,sizeof vis);
    dfs(0,0,0);
    cout<<ans<<' '<<low<<endl;
    return 0;
}

今天的总结:
今天(??)
估分100+100+50
结果0+30+0
(???)
为啥我把读写copy进去的时候忘记改文件名了???
continue 打成 return 为啥还能过样例??? 还查不出来???
第三题???

必须要仔细一点了!!!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值