【题目描述】

爱玩游戏的小 Z 最近又换了一个新的游戏。这个游戏有点特别,需要两位玩 家心有灵犀通力合作才能拿到高分。 游戏开始时,两位玩家会得到同一个数字 N,假设这个数字共有 t 位数码, 然后两位玩家可以分别对这个数字的 t 位数码进行 K 次交换,但要求每次交换后 得到的数字不能有前导 0,最后游戏得分为两位玩家的最终数字的差的绝对值。 小 Z 想知道,对于给定的数字,最大得分是多少。

【输入格式】

第一行为测试数据组数 T(1≤T≤10)。 每组测试数据仅一行,包含两个整数 N 和 K,含义见题面。

【输出格式】

对于每组数据输出仅一行,包含一个整数,表示最大得分。

【样例输入】

5

12 1

213 2

998244353 1

998244353 2

998244353 3

【样例输出】

9

198

699599970

759599973

764599473

【样例解释】

第一个数据中,变换后可得到 21 与 12,差值是 9; 第二个数据中,变换后可得到 321 与 123,差值是 198; 后三个数据,变换 1/2/3 次分别可得到 998544323 与 298944353,998544332 与 238944359,998544332 与 233944859,差值分别为 699599970,759599973 与 764599473。

思路:

这道题贪心错误,不能直接找后面靠后的比他大的位和他交换,989244343可以hack掉,或者别的数据都可以,直接爆搜,从高位到低位,注意求最小值时要特判前导零 + dfs。

代码:

#include<cstdio>
#include<iostream>
#include<algorithm>
#include<cstring>
#define INF 999999999
using namespace std; inline int read() {
int x = 0,f = 1; char s = getchar();
while(s < '0' || s > '9') {if(s == '-') f = -1;s = getchar();}
while(s >= '0' && s <= '9') {x = x * 10 + s - '0';s = getchar();}
return x * f;
} int T;
int n,m;
int A,B,tot;
int num[12],cnt;
int a[12],b[12]; inline void dfs_min(int k,int opt) {
if(k <= 0 || opt >= tot) {
int sum = 0;
for(int i = 1;i <= tot;i ++) sum = sum * 10 + a[i];
A = min(A,sum);
return ;
}
if(opt == 1) {
for(int i = opt + 1;i <= tot;i ++)
if(a[i] <= a[opt] && a[i] != 0) {
swap(a[i],a[opt]);
dfs_min(k - 1,opt + 1);
swap(a[i],a[opt]);
} }
else {
for(int i = opt + 1;i <= tot;i ++)
if(a[i] <= a[opt]) {
swap(a[i],a[opt]);
dfs_min(k - 1,opt + 1);
swap(a[i],a[opt]);
}
}
dfs_min(k,opt + 1);
} inline void dfs_max(int k,int opt) {
if(k <= 0 || opt >= tot) {
int sum = 0;
for(int i = 1;i <= tot;i ++) sum = sum * 10 + b[i];
B = max(B,sum);
return ;
}
for(int i = opt + 1;i <= tot;i ++)
if(b[i] >= b[opt]) {
swap(b[i],b[opt]);
dfs_max(k - 1,opt + 1);
swap(b[i],b[opt]);
}
dfs_max(k,opt + 1);
} inline void Work() {
memset(a,0,sizeof(a));
memset(b,0,sizeof(b));
memset(num,0,sizeof(num));
cnt = tot = 0;
n = read(),m = read();
A = INF,B = 0;
while(n) num[++ cnt] = n % 10,n /= 10;
for(int i = cnt;i;i --)
a[++ tot] = num[i],b[tot] = num[i];
dfs_min(m,1); dfs_max(m,1);
cout << B - A << endl;;
} int main() {
freopen("cooperate.in","r",stdin);
freopen("cooperate.out","w",stdout); T = read();
while(T --) Work(); fclose(stdin); fclose(stdout);
return 0;
}

  

最新文章

  1. Python环境安装
  2. 全面分析Java的垃圾回收机制
  3. 改写《python基础教程》中的一个例子
  4. iOS打包ipa包
  5. 【Moqui业务逻辑翻译系列】Story of Online Retail Company 在线零售公司的故事
  6. Oracle普通索引,唯一索引,主键的区别
  7. python3中输出不换行
  8. Linux下vi编辑器粘贴复制剪切功能
  9. Session丢失,都是CDN惹的祸
  10. POJ3617 简单字符串
  11. python 中变量的命名规范
  12. SQLServer服务器数据库之间的数据操作(完整版)
  13. Js控制iphone端的input/textarea元素失去焦点时隐藏键盘
  14. 连接linux 服务器
  15. 代码从stepping stone搬移到内存
  16. Hive 外部表的练习(多表关联查询,以及分组,子查询)
  17. 【重磅】Spring Boot 2.0权威发布
  18. Dev-Tips
  19. Tomcat报错: Failed to start component [StandardEngine[Catalina].StandardHost[localhost].StandardContext[/myApp]]
  20. 1.浅谈CLR

热门文章

  1. 前端模拟数据接口json-server
  2. 如何找到程序的真正入口mainCRTStartup
  3. Go语言操作Redis
  4. 第一讲,DOS头文件格式
  5. hdu 2609 字符串最小表示法 虽然不是很懂 还是先贴上来吧。/,。/
  6. docker第一篇 容器技术入门
  7. 微信小程序登录获取手机号
  8. OnePlus5刷 TWRP
  9. QT版本下载链接
  10. nodejs request module里的json参数的一个坑