LA2965 n个数中选出最多个数异或和为0
intput
n 1<=n<=24
n串只有大写字母的字符串
output
选出最多个字符串且每个大写字母出现的次数为偶数
第一行输出个数x
第二行输出x个字符串的下标
做法:将每个字符串转化为一个26bit数,1为奇数个大写字母,0为偶数个,则转化为找出最多个数异或和为0,直接枚举为O((2^n)*n),但只有a^a=0,所以将n个数分为两半(中途相遇法),复杂度降为O((2^(n/2))logn)
注意:异或和左半为0和右半为0的要特判,且右半要全部判完,因为可能出现2+3<5+1
#include <cstdio>
#include <queue>
#include <cstring>
#include <iostream>
#include <cstdlib>
#include <algorithm>
#include <vector>
#include <map>
#include <set>
#include <ctime>
#include <cmath>
#define MAX 100000 using namespace std;
struct node
{
int mark,n;
node operator+(const node&b)const
{
return (node){mark|b.mark,n+b.n};
}
bool operator<(const node&a)const
{
return n<a.n;
}
};
int a[],c[],n,ch,num;
char s[];
node maxn;
map<int,node>q;
map<int,node>::iterator qsum;
void dfs(int x,int mark,int sum,int nn)
{
if(x==n>>)
{
q.insert(make_pair(sum,(node){mark,nn}));
if(sum==) maxn=max(maxn,(node){mark,nn});
return;
}
sum^=a[x];
nn++;
mark|=<<x;
dfs(x+,mark,sum,nn);
sum^=a[x];
nn--;
mark&=~(<<x);
dfs(x+,mark,sum,nn);
}
void find(int x,int mark,int sum,int nn)
{
if(x==n)
{
qsum=q.find(sum);
if(qsum!=q.end()) maxn=max(maxn,qsum->second+(node){mark,nn});
if(sum==) maxn=max(maxn,(node){mark,nn});
return;
}
sum^=a[x];
nn++;
mark|=<<x;
find(x+,mark,sum,nn);
sum^=a[x];
nn--;
mark&=~(<<x);
find(x+,mark,sum,nn);
}
int main()
{
freopen("/home/user/桌面/in","r",stdin);
while(scanf("%d%*c",&n)==)
{
memset(a,,sizeof(a));
for(int i=;i<n;i++)
{
memset(c,,sizeof(c));
scanf("%s",s);
for(int j=;s[j];j++) c[s[j]-'A']++;
for(int j=;j<;j++) if(c[j]&) a[i]|=<<j;
}
if(n==)
{
if(a[]) puts("0\n");
else puts("1\n1");
continue;
}
q.clear();
maxn=(node){,};
dfs(,,,);
find(n>>,,,);
if(maxn.n)
{
printf("%d\n",maxn.n);
for(int i=,j=;i<n;i++)
{
if(maxn.mark&(<<i))
{
if(j) putchar(' ');
printf("%d",i+);
j=;
}
}
printf("\n");
}
else puts("0\n");
}
//printf("time=%.3lf",(double)clock()/CLOCKS_PER_SEC);
return ;
}
LA2965 n个数中选出最多个数异或和为0的更多相关文章
- 一道经典的面试题:如何从N个数中选出最大(小)的n个数
转载:https://zhidao.baidu.com/question/1893908497885440140.html 这个问题我前前后后考虑了有快一年了,也和不少人讨论过.据我得到的消息,Goo ...
- JAVA 递归实现从n个数中选取m个数的所有组合
这周Java课程有个小作业:Java递归实现从n个数中选取m个数的所有组合 代码如下: //其中 n 取 1,2,3,4,5 五个数, m 取 3 package javaText; public c ...
- C++从多n个数中选取m个数的组合
//start 是从哪个开始取, picked代表已经取了多少个数 //process和data是全局变量数组 //语言说明比较难,我举个例子吧 //从[ 1, 2, 3, 4 ]中选取 2 个数 / ...
- Poj The xor-longest Path 经典题 Trie求n个数中任意两个异或最大值
Time Limit: 2000MS Memory Limit: 65536K Total Submissions: 5646 Accepted: 1226 Description In an ...
- 找出n个数中重复最多的10个数
题目很清晰,直接上python代码 import pandas as pd import copy class BenchMark: def __init__(self): self.MIN = 10 ...
- hdu 5265 技巧题 O(nlogn)求n个数中两数相加取模的最大值
pog loves szh II Time Limit: 4000/2000 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others) ...
- SGU 275 To xor or not to xor 高斯消元求N个数中选择任意数XORmax
275. To xor or not to xor The sequence of non-negative integers A1, A2, ..., AN is given. You are ...
- 从1到n整数中1的个数
[问题]求出1~13的整数中1出现的次数,并算出100~1300的整数中1出现的次数?为此他特别数了一下1~13中包含1的数字有1.10.11.12.13因此共出现6次,但是对于后面问题他就没辙了.A ...
- LA2965侏罗纪(异或和为0的最大数字个数)
题意: 给你n个字符串,让你在里面找到一个字符串集合使得这些字符串中所有的字母出现的次数和为偶数,输出集合的最大个数,和ASCII最小的解. 思路: 考虑到每个字符串中所有的字 ...
随机推荐
- POJ 3268 Silver Cow Party(dij+邻接矩阵)
( ̄▽ ̄)" #include<iostream> #include<cstdio> #include<algorithm> #include<cs ...
- Struts入门学习(一)
刚开始学习框架的时候感觉很简单,都是用到javaEE的相关框架,自己就想研究源码,但是学了很久之后毫无头绪,所以还是扎扎实实学好Struts毕竟框架做起来要比自己写javaEE要简单,下面我们就来一步 ...
- Linux中kettle连接hadoop并传数据(5)
http://wiki.pentaho.com/display/BAD/Loading+Data+into+HDFS 新建job
- Unity3D 回合制 网上源码 目前还在研究构思
我们已将回合制的战斗模式讲解得很清楚了.那么,如果在Unity3D游戏中实现一个回合制游戏呢?我们从最简单的一对一模式来设计回合制游戏的原型.我们可以游戏的状态划分为下面三种状态: 1. ...
- python--sum函数--sum(axis=1)
平时用的sum应该是默认的axis=0 就是普通的相加,当加入axis=1以后就是将一个矩阵的每一行向量相加. 例如: >>>import numpy as np >>& ...
- 解决 .NET Core 中 GetHostAddressesAsync 引起的 EnyimMemcached 死锁问题
在我们将站点从 ASP.NET + Windows 迁移至 ASP.NET Core + Linux 的过程中,目前遇到的最大障碍就是 —— 没有可用的支持 .NET Core 的 memcached ...
- HTML+CSS Day10实例
1.家居大视野 效果图: 代码: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "h ...
- ValueStack背后的OGNL表达式
原文地址:http://blog.csdn.net/li_tengfei/archive/2010/12/25/6098134.aspx 前言: Strut2的Action类通过属性可以获得所有相关的 ...
- JavaScript(7)——事件2.0
事件 [事件类型] 不同的事件类型具有不同的信息. [UI事件] 指的是那些不一定与用户操作有关的事件.当用户与页面上的元素交互时触发. load事件:当页面完全加载后,就会 触发window 上面的 ...
- csdn如何转载别人的文章
1.找到要转载的文章,用chrome浏览器打开,右键选择审查元素 2.在chrome中下方的框里找到对应的内容,html脚本中找到对应的节点,选中节点,网页上被选中内容会被高亮显示,然后右键菜单选中 ...