//never use translation
#include<bits/stdc++.h>
using namespace std;
int k;
char a[20];//储存每个数的数值
int times[20];//mn次数
int timess[20];//mx次数
int len;
int mn;
int mx;
int kk,sum;
void solve()
{
    kk=0,sum=0;
    if(a[times[1]]==0)
        return;
    for(int i=1;i<=len;i++)
        timess[i]=times[i];//储存现在的数位情况,times因排序而发生递增
    for(int i=1;i<=len;i++)
    {
        sum=sum*10+a[times[i]];//记录按照数位变化而产生的数值
        if(timess[i]!=i)//该位置发生变动
        {
            for(int j=i+1;j<=len;j++)
            {
                if(timess[j]==i)//找到和前面发生变动的数字exchange的数位
                {
                    swap(timess[i],timess[j]);//交换以免在后续的查找中将交换的数位查找两次
                    kk++;//查找次数++
                    if(kk>k)
                        return;
                    break;//寻找下一个发生变动的数位
                }
            }
        }
    }
    if(kk>k)
        return;
    mx=max(mx,sum);
    mn=min(mn,sum);
    return;
}
int main()
{
    int t;
    scanf("%d",&t);
    while(t--)
    {
        scanf("%s%d",a+1,&k);
        len=strlen(a+1);
    if(len==10)
            printf("1000000000 1000000000\n");//剪枝
    else
    {
        memset(times,0,sizeof(times));
        memset(timess,0,sizeof(timess));
        for(int i=1;i<=len;i++)
        {
            a[i]-='0';
            times[a[i]]++;
            timess[a[i]]++;//计数
        }
        if(k>=len-1)//剪枝
        {
            for(int i=1;i<=9;i++)//第一位非零
            {
                if(times[i])
                {
                    printf("%d",i);
                    times[i]--;
                    break;
                }
            }
            for(int i=0;i<=9;i++)
            {
                while(times[i])//将所有数全部贪心输出
                {
                    printf("%d",i);
                    times[i]--;
                }
            }
            printf(" ");
            for(int i=9;i>=1;i--)//和上面反着来
            {
                if(timess[i])
                {
                    printf("%d",i);
                    timess[i]--;
                    break;
                }
            }
            for(int i=9;i>=0;i--)
            {
                while(timess[i])
                {
                    printf("%d",i);
                    timess[i]--;
                }
            }
            printf("\n");
        }
        else//还有一种利用暴力dfs的方法是最初的想法,听完讲解后觉得按照数位全排列技巧性高一点
        {
            mx=0,mn=1e10;//反向设定最值
            for(int i=1;i<=len;i++)
            {
                times[i]=i;//记录原始数位
            }
            do
            {
                solve();
            }while(next_permutation(times+1,times+1+len));//至少进行一次更新最值
            //全排列函数按照字典序寻找下一种情况,这里按照数位从最小的1~n开始枚举到n~1
            //prev_permutation按照字典序寻找上一种情况
            printf("%d %d\n",mn,mx);
        }
    }
    }
    return 0;
}

//遇见数字较大然而问题和单独的数有关时联想可否用数位思想解决,数位和数之间建立联系,数位处理问题时较为简单便利

2018杭电多校第五场1002(暴力DFS【数位】,剪枝)的更多相关文章

  1. 2018杭电多校第六场1009(DFS,思维)

    #include<bits/stdc++.h>using namespace std;int a[100010];char s[20];int zhiren[100010];vector& ...

  2. hdu6356 Glad You Came 杭电多校第五场 RMQ ST表(模板)

    Glad You Came Time Limit: 10000/5000 MS (Java/Others)    Memory Limit: 262144/262144 K (Java/Others) ...

  3. 2018杭电多校第三场1003(状态压缩DP)

    #include<bits/stdc++.h>using namespace std;const int mod =1e9+7;int dp[1<<10];int cnt[1& ...

  4. 2017杭电多校第五场11Rikka with Competition

    Rikka with Competition Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/O ...

  5. 2017杭电多校第五场Rikka with Subset

    Rikka with Subset Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/65536 K (Java/Others ...

  6. [2019杭电多校第五场][hdu6630]permutation 2

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6630 题意为求出1-n,n个数的全排列中有多少种方案满足第一位为x,第n位为y,且相邻数字绝对值之差不 ...

  7. [2019杭电多校第五场][hdu6624]fraction

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6624 题意为求最小的b满足$a*b^{-1}\equiv x(modp)$. 把式子化简一下: $a\ ...

  8. [2019杭电多校第五场][hdu6629]string matching(扩展kmp)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6629 题意求字符串的每个后缀与原串的最长公共前缀之和. 比赛时搞东搞西的,还搞了个后缀数组...队友一 ...

  9. [2019杭电多校第五场][hdu6628]permutation 1

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=6628 题意为求字典序第k小的差异数组,差异数组p满足p[i]=a[i+1]-a[i]. 头铁的爆搜,因 ...

随机推荐

  1. SQL嵌套子查询和相关子查询的执行过程有什么区别(推荐)

    SQLServer子查询可以分为 相关子查询 和 嵌套子查询 两类.前提, 假设Books表如下: 类编号 图书名 出版社 价格 ----------------------------------- ...

  2. python-多线程趣味

    假设一个程序员,想听歌,但是又想敲代码,于是又: 我听完歌就去敲代码: #! /usr/bin/env python #coding=utf-8 import time def matter1(mus ...

  3. 嵌套list的实例化

    在LeetCode上遇到这样返回值 public class Solution { public List<List<Integer>> levelOrder(TreeNode ...

  4. .NET接入微信支付(一)JS API接入 V3

    前段时间刚接完银联支付,完事后又接了微信支付,前段时间一直急着上线,微信的接入一直没有时间处理,今天我们就来整理一下微信支付的接入方法和要点. 配置: 首先呢微信支付需要通过审核,审核啥的准备工作我就 ...

  5. linux下dns设置详解

    DNS就是Domain Name System,它能够把形如www.21php.com这样的域名转换为211.152.50.35这样的IP地址;没有DNS,浏览21php.com这个网站时,就必须用2 ...

  6. 通过pip3安装ipython

    操作系统:Centos7.4:ipython可以用来测试python语句,故需要安装. 首先需要安装epelde的扩展库: easy_install是由PEAK(Python Enterprise A ...

  7. Linux 文件名颜色

    在Linux中,文件的颜色都是有含义的.其中, 蓝色表示目录 绿色表示可执行文件 红色表示压缩文件 浅蓝色表示链接文件 灰色表示其它文件 红色闪烁表示链接的文件有问题了 黄色是设备文件,包括block ...

  8. 使用python对文件夹里面所有代码行数进行统计。

    统计目录下所有的代码个数和总行数. # -*- coding: utf-8 -*- # @Author : ydf import json import os from pathlib import ...

  9. mybatis 学习二 conf xml 配置信息

    xml映射配置文件      这个xml文件主要包括一下节点信息      * properties 属性      * settings 设置      * typeAliases 类型命名     ...

  10. js 函数定义的两种方式以及事件绑定(扫盲)

    一.事件(例如:onclick)绑定的函数定义放在jsp前面和放后面没影响 二. $(function() { function func(){}; }) onclick通过如下方式绑定事件到jsp中 ...