//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. phalcon:官方多模块支models层,mode数据库配置(二)

    phalcon:官方多模块支models层,mode数据库配置(二) 利用:\pahlcon\mvc\model\Manager::registerNamespaceAlias()方法获取多模块下的m ...

  2. Delphi 读取 c# webservice XML的base64编码图片字符串转化图片并显示

    Delphi 读取 c# webservice XML的base64编码图片字符串转化图片并显示 在 开发中遇到应用c#及asp.net的在的webservice 保存图片并以xml文件形式现实出来 ...

  3. JS获取ListBox所有项

    JS代码: var listbox = document.getElementById("<%=lbCustom.ClientID %>"); var values = ...

  4. python代码docstring生成文档之sphinx

    在使用python中,我们一般在模块,类,函数下使用docstring添加字符串说明性文档,使开发人员更好的可以看懂此代码是做什么用的.然而写了那么多的注释,我们想要一篇文档怎么办,第一种办法不可能将 ...

  5. python基础-条件语句if

    if语句: if 判断条件: 执行语句 else: 执行语句 flag = Falsename = 'huipaodexiong'if name == 'python':    flag = True ...

  6. L106 Three things we learned from day one at the World Cup

    Hosts Russia got the World Cup off to a flying start by hammering Saudi Arabia 5-0 in the opening ga ...

  7. Android SQLite学习指南

    一.SQLite简介 在Android平台上,集成了一个嵌入式关系型数据库—SQLite,SQLite3支持 NULL.INTEGER.REAL(浮点数字).TEXT(字符串文本)和BLOB(二进制对 ...

  8. Python语言及其应用 第2章

  9. 调试 ASP 程序脚本

    调试 ASP 脚本 无论您的计划多么精密.经验多么丰富,脚本错误 (bug) 可能在最初就使您的 ASP 服务器端的脚本无法正确运行.也就是说调试,即查找和纠正脚本错误,对开发一个成功的和强健的 AS ...

  10. PG peered实验

    标签(空格分隔): ceph,ceph实验,pg 1. 创建一个文件,并把该文件作为对象放到集群中: [root@node1 ~]# echo "this is test! " & ...