leetcode752打开转盘锁

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
思路

  1. 这种相当于找出一条路,其中路不包含deadens中的节点
  2. 找路的方式相当于每一位都进行翻转,相当于树的层序遍历,每一位都有两个节点,看能不能找到目的节点,并把路径长度记录下来
  3. 使用队列进行层序遍历
  4. 比较麻烦的是用数组模拟队列,以及数字翻转,数字翻转的思路参考用数组模拟循环队列。
    环形队列: link.
  5. 使用数组记录不可走的节点

层序遍历的模板

queue.pushback(start);
while (!queue.empty()){
	for(i=0;i<queue.size();i++){	
		dequeue(queue,q);
		visit(q);
		//对q的子节点进行操作并进栈
		queue.pushback(q.child());
	}
	result++;
}

代码

int openLock(char ** deadends, int deadendsSize, char * target){
int result =0;
    int i,j,k;
    int flag[10000];//记录不可走的节点
    memset(flag,0,sizeof(int)*10000);
    for(i=0;i<deadendsSize;i++){
        flag[atoi(deadends[i])]=1;;
    }
    if(flag[atoi(target)]||flag[atoi("0000")])
        return -1;
    char queue[20000][5];//遍历使用的队列
    int top = 0,front = -1;
    strcpy(queue[top++],"0000");
    front++;
    while(front<top){
        int len = top -front;
        for(i=0;i<len;i++){
            char temp[5];
            strcpy(temp,queue[front]);
            front++;
            if(strcmp(temp,target)==0){
                return result;
            }
            for(j=0;j<4;j++){
                for(k=-1;k<2;k+=2){//0-9 0-1,思路就是环形队列中的push和pop
                    char t = (temp[j]-'0'+10+k)%10 + '0';
                    char temp_x[5];
                    strcpy(temp_x,temp);
                    temp_x[j] = t;
                    if(flag[atoi(temp_x)]==0){
                        flag[atoi(temp_x)]=1;
                        strcpy(queue[top++],temp_x);
                    }

                }
            }
        }
        result++;
    }
    result = -1;
    return result;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值