题意:

时间限制:2000ms
单点时限:1000ms
内存限制:256MB

描写叙述

小冰的N个机器人兄弟排成一列,每一个机器人有一个颜色。

如今小冰想让同一颜色的机器人聚在一起。即随意两个同颜色的机器人之间没有其它颜色的的机器人。

如果随意相邻的两个机器人能够交换位置。请问最少须要多少次交换?

输入

第一行为一个整数T。为数据组数,之后每组数据两行。

第一行为N和K,表示机器人的个数与颜色的总数。

接下来一行N个数,第i个数表示第i个机器人的颜色,取值范围为1到K。

输出

对于每组数据输出一行,形如"Case #X: Y"。X为数据组数,从1開始。Y为最少的交换步数。

数据范围

1 ≤ T ≤ 20

1 ≤ N ≤ 105

小数据

1 ≤ K ≤ 3

大数据

1 ≤ K ≤ 16

题解:

1.状态压缩dp,dp[11001]表示1,2,5这三种机器人已经达到要求(而且1,2,5排在3,4号机器人的前面)所须要的最

少步数

2.举个样例说明:1,2,3,4,5这五种机器人。当dp[10001]转移到dp[11001]。要想让2号达到要求。而且已知1,5号机器人

已经达到要求,就须要让2,3。4号机器人通过交换位置使得,2号机器人排在一起,且处于3。4号机器人的前边

3.达到这个目标。须要知道:逆序数对==通过交换最少的次数达到'有序'

4.预处理i号机器人(范围[1,k])到j号机器人(范围[1,k])所产生的逆序对数pre[i][j]

5.最后达到3的目标。pre[2][3] + pre[2][4]就是将2号机器人换到3,4号机器人前方所须要的步数

总结:

1.開始想用贪心写。写完之后才发现错了

2.看到网上说状态压缩,事实上就是暴力,想了好多天依然没有想出来

3.看到逆序对数==最少交换步数才差点儿相同想出来怎么做的

4.感觉还须要努力。加强全面思考问题的能力

5.近期在学习图像处理,opencv,进度太慢被老师说了,须要提高工作效率!

6.项目这样的事情还是要快。快,快,不能像ACM享受慢慢思考并弄懂问题的快乐。也可能与平时效率低下不愿面对自

己的问题有关

7.总之,不同的科目有不同的学习方法,可是无论什么都须要提高效率。而且都要弄懂原理

8.不纠结于细节,高速找到自己须要学习的目标。

#include<iostream>
#include<cstring>
#include<cstdio>
#include<vector>
using namespace std;
typedef long long LL;
#define MAXN 100005
#define INF 0x3f3f3f3f3f3f3f3f
#define MAXM 16
#define MAXP 65536
int n,m,pre[MAXM][MAXM];
LL dp[MAXP];
vector<int>vec[MAXM];
int main()
{
int _,cur;
for(int kcas = scanf("%d",&_);kcas <= _;kcas++)
{
scanf("%d%d",&n,&m);
for(int i = 0;i < m;i++)vec[i].clear();
for(int i = 0;i < n;i++)
{
scanf("%d",&cur);
vec[cur - 1].push_back(i);
}
memset(pre,0,sizeof(pre));
for(int i = 0;i < m;i++)
for(int j = 0;j < m;j++)if(i != j)
for(int u = 0,v = 0;u < vec[i].size();u++)
{
while(v < vec[j].size() && vec[i][u] > vec[j][v])
v++;
pre[i][j] += v;
}
memset(dp,0x3f,sizeof(dp));
dp[0] = 0;
int cnt = 1 << m;
for(int i = 0;i < cnt;i++)
{
for(int j = 0;j < m;j++)if(!(i >> j & 1))
{
LL num = 0;
for(int k = 0;k < m;k++)if(!(i >> k & 1) && k != j)
num += pre[j][k];
dp[i | (1 << j)] = min(dp[i | (1 << j)],dp[i] + num);
}
}
printf("Case #%d: %lld\n",kcas,dp[(1 << m) - 1]);
}
}

hihocoder #1170 机器人 &amp;&amp; 编程之美2015复赛的更多相关文章

  1. hihocoder 微软编程之美2015 初赛 第二场(暴力+字典序+图论+思维算法)

    题目1 : 扑克牌 时间限制:2000ms 单点时限:1000ms 内存限制:256MB 描述 一副不含王的扑克牌由52张牌组成,由红桃.黑桃.梅花.方块4组牌组成,每组13张不同的面值.现在给定52 ...

  2. 编程之美2015初赛第一场 hihoCoder #1156 : 彩色的树(染色问题)

    #1156 : 彩色的树 时间限制:2000ms 单点时限:1000ms 内存限制:256MB 描述 给定一棵n个节点的树,节点编号为1, , …, n.树中有n - 1条边,任意两个节点间恰好有一条 ...

  3. 编程之美2015 资格赛 hihocoder 题目2: 回文字符序列

    思路:暴力搜,用BFS的方式,生成每一种可能,再对每一种可能进行判断是否回文,进行统计.严重超时!计算一个25个字符的,大概要20多秒! #include <iostream> #incl ...

  4. hihocoder 微软编程之美2015 初赛 第一场 (树算法 + 暴力思想 + 搜索思想)

    题目1 : 彩色的树 时间限制:2000ms 单点时限:1000ms 内存限制:256MB 描述 给定一棵n个节点的树,节点编号为1, 2, …, n.树中有n - 1条边,任意两个节点间恰好有一条路 ...

  5. 编程之美2015资格赛 题目2 : 回文字符序列 [ 区间dp ]

    传送门 题目2 : 回文字符序列 时间限制:2000ms 单点时限:1000ms 内存限制:256MB 描述 给定字符串,求它的回文子序列个数.回文子序列反转字符顺序后仍然与原序列相同.例如字符串ab ...

  6. 2017“编程之美”终章:AI之战勇者为王

    编者按:8月15日,第六届微软“编程之美”挑战赛在选手的火热比拼中圆满落下帷幕.“编程之美”挑战赛是由微软主办,面向高校学生开展的大型编程比赛.自2012年起,微软每年都在革新比赛命题.紧跟时代潮流, ...

  7. 编程之美2014挑战赛 复赛 Codehunt平台试题答案

    var appInsights=window.appInsights||function(config){ function r(config){t[config]=function(){var i= ...

  8. LeetCode:Climbing Stairs(编程之美2.9-斐波那契数列)

    题目链接 You are climbing a stair case. It takes n steps to reach to the top. Each time you can either c ...

  9. 编程之美2.5:寻找最大的K个数

    编程之美2.5:寻找最大的K个数 引申:寻找第k大的数: 方法一: // 选择第k大的数(通过改进快速排序来实现) public static void SelectShort(int[] array ...

随机推荐

  1. 《jquery实战》javascript 必知必会(1)

    A1 javascript对象的基本原理 JS 的 Object 与其他兄弟面向对象所定义的根本对象,几乎没有什么共同之处. JS 的 Object 一旦创建,它不持有任何数据,而且不表示什么语义. ...

  2. Java编程的逻辑 (61) - 内存映射文件及其应用 - 实现一个简单的消息队列

    本系列文章经补充和完善,已修订整理成书<Java编程的逻辑>,由机械工业出版社华章分社出版,于2018年1月上市热销,读者好评如潮!各大网店和书店有售,欢迎购买,京东自营链接:http:/ ...

  3. django中的view测试和models测试样例

    感觉用model_mommy比factory_boy要好些. 如果Models.py如下: from django.db import models from django.contrib.auth. ...

  4. web程序快速开发

    关于web程序快速开发个人见解以及经历 由于在之前公司业务的发展,需要在基于核心业务的基础上开发其他较为独立的业务系统,所以就有了这个基于Dapper,DDD概念的基础框架,由于个人基于这个框架已经经 ...

  5. ResultCode 自定义错误状态码

    public class ResultCode { // 成功状态码 public static final int SUCCESS = 1; // -------------------失败状态码- ...

  6. 【noip模拟赛1】古韵之乞巧 (dp)

    描述 闺女求天女,更阑意未阑. 玉庭开粉席,罗袖捧金盘. 向月穿针易,临风整线难. 不知谁得巧,明旦试相看. ——祖咏<七夕> 女子乞巧,是七夕的重头戏.古时,女子擅长女红被视为一种重要的 ...

  7. Wireshark网络分析就这么简单

    tcpdump抓包命令: root#tcpdump -I eth0 -s 80 -w /tmp/tcpdump.cap 注:其中80表示,只抓每个包的前80个字节. 抓包时就筛选自己需要的包: Wir ...

  8. P1890 gcd区间

    P1890 gcd区间我一开始80分暴力,模拟100做法dpO(n^2+m)f[i][j]表示i到j的 gcd初始化f[i][i]=i;f[i][j]=gcd(f[i][j-1],a[j]);这样查询 ...

  9. 003.iSCSI客户端管理

    一 启动器介绍 iSCSI启动器通常在软件中实施,也可以采用硬件启动器.软件启动器需要安装iSCSI-initiator-utils软件包.包含如下文件: /etc/iscsi/iscsid.conf ...

  10. 003.RAID管理

    一 查看RAID组信息 [root@kauai ~]# mdadm -D /dev/md0 /dev/md0: Version : 1.2 Creation Time : Mon Aug 29 22: ...