Swap Digits

题目描述#

一个十进制整数n,你最多可以任意交换相邻的两个数码k次,请问能得到多少个不同的无前导0的数?

输入#

第一行是一个整数T。 以后每行一个样例,为两个整数n,k。

输出#

每行输出一个样例的结果。

样例输入#

复制代码
2 
10 1 
123 2

样例输出#

复制代码
1
5

样例解释#

第一个样例只能得到10;第二个样例可以得到123,132,231,213,312。

解题思路

复制代码
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
typedef struct Node{
    long long num;
    int steps;
}Node;
#define MAX_QUEUE 100010
Node queue[MAX_QUEUE];
int front,rear;
#define MAX_HASH 100010
long long hash_set[MAX_HASH];
int hash_size;
int in_hash(long long num){
    for(int i=0;i<hash_size;i++){
        if(hash_set[i]==num){
            return 1;
        }
    }
    return 0;
}
void add_hash(long long num){
    if(!in_hash(num)){
        hash_set[hash_size++]=num;
    }
}
int get_digits(long long n){
    if(n==0) return 1;
    int count=0;
    while(n>0){
        count++;
        n/=10;
    }
    return count;
}
long long swap_digits(long long n,int i,int m){
    long long upp=100;
    long long low=1;
    for(int j=0;j<i;j++){
        upp*=10;
        low*=10;
    }
    long long a=n/upp;
    long long c=n%low;
    long long b=(n/low)%100;
    if(i==m-2 && (b%10==0)){
        return -1;
    }
    b=(b%10)*10+(b/10);
    long long x=a*upp+b*low+c;
    return x;
}

int main(){
    int T;
    scanf("%d",&T);
    while(T--){
        long long n;
        int k;
        scanf("%lld %d",&n,&k);
        front = rear = 0;
        hash_size = 0;
        queue[rear].num = n;
        queue[rear].steps = 0;
        rear++;
        add_hash(n);
        while(front<rear){
            Node current=queue[front++];
            if(current.steps>=k){
                continue;
            }
            int m=get_digits(current.num);
            for(int i=0;i<m-1;i++){
                long long new_num=swap_digits(current.num,i,m);
                if(new_num!=-1){
                    if(!in_hash(new_num)){
                        add_hash(new_num);
                        queue[rear].num=new_num;
                        queue[rear].steps=current.steps+1;
                        rear++;
                    }
                }
            }
        }
        printf("%d\n",hash_size);
    }
    return 0;
}

时间超限,正在改进,可以催催,万一我忘记了嘞嘻嘻

相关推荐
枕星而眠2 小时前
C 语言结构体硬核总结:内存对齐、#pragma pack、位段、柔性数组(面试+工程双指南)
c语言·后端·面试·柔性数组
三品吉他手会点灯3 小时前
C语言学习笔记 - 5.C概述 - C的应用领域
c语言·笔记·学习
mount_myj3 小时前
填数【C语言】
c语言
三品吉他手会点灯3 小时前
C语言学习笔记 - 4.C概述 - C的特点
c语言·笔记·学习
她说彩礼65万4 小时前
C语言 函数指针
c语言·开发语言·算法
算法鑫探4 小时前
贪心算法(C 语言实现)及经典应用
c语言·数据结构·算法·贪心算法
C语言小火车4 小时前
嵌入式实习面试问题:那个动态内存是怎么样分配的?
c语言·开发语言·c++·嵌入式硬件·面试
拾光Ծ4 小时前
【Linux系统编程】深入理解命名管道(Named Pipe):从原理到实战的完整指南
linux·c语言·linux系统编程·进程间通信·ipc·命名管道
HZ·湘怡4 小时前
任意位置 单链表 回归
c语言·链表