2014_GCJ_A
题目链接:http://code.google.com/codejam/contest/2984486/dashboard#s=p0
最想吐槽的是想些DFS过小数据,居然写不出来,不知道我这半年的ACM生活在干嘛?
先不说直接出最有解,但是DFS这基本的还不会,真是,估计快废了!
DFS过小数据的程序:
#include<iostream>//又臭又长,无语
#include<algorithm>
#include<math.h>
#include<string.h>
#include<string>
#include<set>
#include<map>
#include<cstdio>
int n,l;
int ans;
using namespace std;
string s[],s1[],tem[];
int b[];
int pan()
{
sort(tem+,tem+n+);
for (int i=;i<=n;i++)
if (s1[i]!=tem[i]) return ;
return ;
} void res(int x)
{
for (int i=;i<=n;i++)
tem[i][x]^=;//PS这里注意一下,字符为‘0’,或者‘1’;可以算出字符'0'^1='1','1'^1='0';
}
void rec(int x)
{
for (int i=;i<=n;i++)
tem[i][x]^=;
} void dfs(int t,int k)
{
if (t==l)
{
if (pan()) ans=min(ans,k);return; }
dfs(t+,k);
res(t);
dfs(t+,k+);
rec(t);
} int main()
{
int t;
freopen("A-small-practice.in","r",stdin);
freopen("out.txt","w",stdout);
cin>>t;
for (int o=;o<=t;o++){
ans=;
memset(b,,sizeof(b));
cout<<"Case #"<<o<<": ";
cin>>n>>l;
for (int i=;i<=n;i++) {cin>>s[i];tem[i]=s[i];}
for (int i=;i<=n;i++) cin>>s1[i];
sort(s1+,s1+n+);
dfs(,);
if (ans<)
cout<<ans<<endl;
else cout<<"NOT POSSIBLE"<<endl;
}
return ;
}
正解是:枚举第I个数,因为存在解的话肯定是A中第I个数与B第一个数相同,然后根据两者数字的不同去跟新其他位数上的数!复杂度大概是O(N*N*L);
部分代码: for (int i=1;i<=n;i++){
for (int j=;j<=n;j++) ss[j]=s[j]; int now=;
for (int j=;j<l;j++)
if (ss[][j]!=s1[i][j]){
for (int k=;k<=n;k++)
ss[k][j]^=;
now++;
} sort(ss+,ss+n+); int flag=;
for (int k=;k<=n;k++)
if (ss[k]!=s1[k]){flag=;break;}
if (!flag) ans=min(ans,now);
}
等下再做做位运算
2014_GCJ_A的更多相关文章
随机推荐
- Android图表
最近需要用到Android里面的折现图,因此在这方面也去做了一些调研.总体发现Android对报表的支持还是非常好的.总体上去研究了两个实现方案,一个是利用Android提供的的AChartEngin ...
- [重点翻译] ASP.NET 4.6的更新 -- 本文只摘录 Web Forms的部分
原文出处:[重点翻译] ASP.NET 4.6的更新 -- 本文只摘录 Web Forms的部分 http://www.dotblogs.com.tw/mis2000lab/archive/2015/ ...
- jQuery学习笔记(6)--复选框控制表格行高亮
<html xmlns="http://www.w3.org/1999/xhtml"> <head runat="server"> &l ...
- hdu 1277 全文检索
题目连接 http://acm.hdu.edu.cn/showproblem.php?pid=1277 全文检索 Description 我们大家经常用google检索信息,但是检索信息的程序是很困难 ...
- 九度oj 1349 数字在排序数组中出现的次数
原题链接:http://ac.jobdu.com/problem.php?pid=1349 二分.. #include<algorithm> #include<iostream> ...
- Karaf 基于 osgi
Karaf是Apache旗下的一个开源项目.Karaf同时也是一个基于OSGi的运行环境,Karaf提供了一个轻量级的OSGi容器,可以用于部署各种组件,应用程序.Karaf提供了很多特性用于帮助开发 ...
- iOS另类的内存管理
iOS的内存管理算是老生常谈的问题了,我们写iOS的时候无时无刻不在涉及到内存管理.从开始的MRR(manual retain-release)到后来ARC(Automatic Reference C ...
- 关于Swift中实现Lazy initialize的方式
在oc中我们通过 -(CardMatchingGame *)game { if(!_game) _game=[[CardMatchingGame alloc] initWithCardCount:[s ...
- Sliverlight Slide 的左右滑动
private void btnPrev_Click(object sender, RoutedEventArgs e) { scrollRule = (scrollRule-) >= ?(sc ...
- jQuery 获取 select 值和文本
jQuery("#select1").val();是取得选中的值, jQuery("#select1").text();就是取得的文本.