关闭

UVA12545 Bits Equalizer

标签: 数学
106人阅读 评论(0) 收藏 举报
分类:

用cnt记录最终的变换次数,cnt1为0-1对的对数,cnt2为1-0的对数,cnt3为?-1与?-0对数之和,cnt4是S串的1的个数,cnt5是T串的1的个数.

那么显然,当cnt4>cnt5的时候是不可能变换成功的,因为S串中1的个数只增不减.然后....就是数学了.当cnt1>=cnt2的时候(即0-1对多于1-0对),我们先将1-0对与0-1对调换位置,调换次数为cnt2,接着考虑剩余的串,剩下的串中只有(cnt1-cnt2)个0-1对,以及cnt3个?对,我们不去详细考虑每个?会变成什么,但是我们可以知道,?对肯定需要cnt3次变换,而且当?全部变换完成,我们需要做cnt1-cnt2次调换或者变换使得剩余的0-1对全都变掉,所以对于剩下的串,我们还需要cnt3+cnt1-cnt2次变换.于是我们知道当cnt1>=cnt2时,我们总共需要cnt=cnt2+cnt3+cnt1-cnt2=cnt1+cnt3次变换.同理,当cnt2>cnt1的时候我们可以得到cnt=cnt1+cnt3+cnt2-cnt1=cnt2+cnt3.于是代码就很好写了....

AC代码如下:

#include <cstdio>
#include <cstring>
using namespace std;

char a1[105],a2[105];

int main(int argc, char const *argv[])
{
	int T,mark=0;
	scanf("%d", &T);
	while(T--)
	{
		mark++;
		scanf("%s%s", a1,a2);
		int cnt=0,cnt1=0,cnt2=0,cnt3=0,cnt4=0,cnt5=0;
		for(int i=0;i<strlen(a1);i++)
		{
			if(a1[i]=='0'&&a2[i]=='1')
				cnt1++;
			else if(a1[i]=='1'&&a2[i]=='0')
				cnt2++;
			else if(a1[i]=='?')
                                cnt3++;
			if(a1[i]=='1')
				cnt4++;
			if(a2[i]=='1')
				cnt5++;
		}
		if(cnt4>cnt5)
		 {
			printf("Case %d: -1\n",mark);
			continue;
		}
		if(cnt1>=cnt2)
                        cnt=cnt3+cnt1;
		else
			cnt=cnt3+cnt2;
		printf("Case %d: %d\n",mark, cnt);
	}
	return 0;
}



0
0
查看评论
发表评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场

Android自带音频均衡器MusicFx分析

Android自带音频均衡器MusicFx分析       种种原因,我要简单分析一个Android中built-in的音频均衡器MusicFx。重点是它的默认值的来历。网上很少有文章讲了这个的除了...
  • kangear
  • kangear
  • 2014-08-01 20:44
  • 9635

音频均衡器Equalizer算法研究与实现

如转载请注明出处! 最近工作需要,对Equalizer算法进行了初步研究,并在本地进行了简单实现。 一. 声学背景 心理声学研究证实人耳可闻的声音频率范围为20Hz--20k...
  • qiumingjian
  • qiumingjian
  • 2015-06-02 11:30
  • 3642

android 沉浸模式记录

Android 4.4以后的版本支持状态栏沉浸模式,通过设置代码或者配置Theme style可以开启沉浸模式。 在简书中有篇文章介绍什么是沉浸式模式,http://www.jianshu.com/...
  • fancylovejava
  • fancylovejava
  • 2015-11-30 19:13
  • 2185

习题8-3 UVA - 12545 Bits Equalizer(贪心)

题意: 输入两个字符串,第一个字符串包括0,1,?,  第二个字符串只包括0和1,问由第一个字符串转换到第二个字符串最少多少个操作? 其中操作有3个, 1.可以把问号变成1或者0。 2.可以交...
  • aozil_yang
  • aozil_yang
  • 2016-06-24 18:19
  • 262

UVa:12545 Bits Equalizer(贪心)

题目链接:https://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=845&page=show_pr...
  • u013520118
  • u013520118
  • 2015-08-22 17:24
  • 215

Uva - 12545 - Bits Equalizer

刚开始想了一个变换顺序,模拟进行操作,写了浩浩荡荡200多行最后WA了,感觉还是方法不对。。。后来从只能0变1,不能1变0入手,应该先满足上1下0的情况,其他的三种情况用简单的变换就可以了。 先用0...
  • zyq522376829
  • zyq522376829
  • 2015-06-23 15:49
  • 920

UVA 12545 Bits Equalizer(瞎搞 贪心)

题意给定 两个字符串,第一个含有0,1,?;第二个含有0,1; 规定三种操作:把0 变成1,把?变成0或1,交换两个数字。 问,使用最少的操作数将第一个串变成第二个串。分析关键是寻找,最优的变换策...
  • baidu_33153085
  • baidu_33153085
  • 2016-09-28 21:24
  • 207

uva 12545——Bits Equalizer

题意:给定两个等长的串s和t,其中s串包括0,1,?,T包含0,1,每次可以把s中的0变成1或者交换任意两个数或者?变成任意01.求由s到t的最小步数。 思路:杂。所有带?的都要变成0或则1...
  • bobodem
  • bobodem
  • 2015-11-01 14:42
  • 197

12545 - Bits Equalizer(贪心?)

这道题我是自己出的思路,一遍A的 ,0.000ms。 看网上的题解大多相仿,我就说说我的思路吧 。 假设字符串 a、b 我们只需要从前向后扫一遍就行了,遇到?跳过去,遇到a[i] = '0'&&a...
  • weizhuwyzc000
  • weizhuwyzc000
  • 2015-07-07 20:03
  • 698

Bits Equalizer 组队赛第二场Regionals 2012, Europe - Southwestern B题

题目:题目链接 题目总体来说不难 ,就是给你一个S串和一个T串,然后问你经过多少次操作可以将S串转换为T串。可以进行的操作有:将0变成1;将?变成 0或者1;交换S中的任意两个字符。 如果最终不能把S...
  • u010057864
  • u010057864
  • 2013-07-22 10:15
  • 644
    个人资料
    • 访问:4209次
    • 积分:253
    • 等级:
    • 排名:千里之外
    • 原创:22篇
    • 转载:0篇
    • 译文:0篇
    • 评论:2条
    最新评论
  • UVA12118

    manweifc: 还有一个问题是每两个奇点,通过连接它们变为偶点,那么奇点个数是奇数时怎么办?这样会剩下一个奇点

  • UVA12118

    manweifc: 请问你怎么知道所有的奇点都可以通过加一条边消除两个奇点的方式变为偶点?如果所有的奇点都不相邻可以这么...