九连环是一种流传于山西省的传统民间的智力玩具,由九个圆环相连成串,以解开为胜。

九连环的九个环,一环扣一环地套在钗上。除了第 1 号环可以随时装上或卸下以外,其它环装上或卸下的条件是:在它的前面仅有紧靠它那一个环在钗上。即:当第 1 ~ i−2 号环都不在钗上,第 i−1 号环在钗上,这时可以装上或卸下第 i 号环。

输入格式
环数 操作(U表示装上, D表示卸下)

输出格式
装上或卸下九连环的操作步骤
每行显示一步操作,具体格式为:
环号: U或D (U表示装上,D表示卸下)

#include<stdio.h>
//1~i-2不在杆上,i-1在杆上,i可装上或取下 
void down(int n);
void on(int n){
   
	if(n>1) on(n-1);		//i-1装在杆上 
	if(n>2) down(n-2);		//i-2从杆上卸下 
	printf("%d: U",n);		//输出装上 
	if(n>2) on(n-2);		//i-2装在杆上 
}

void down(int n){
   
	if(n>2) down(n-2);		//i-2从杆上卸下 
	printf("%d: D",n);		//输出卸下 
	if(n>2) on(n-2);		//i-2装上杆上 
	if(n>1) down(n-1);		//i-1从杆上卸下 
}

int main(){
   
	char a[2];
    scanf("%c %c",&a[0],&a[1]);
	//cin>>a[0]>>a[1];
	int n=a[0]-'0';
	if(a[1]=='U') on(n);
	else down(n);
	return 0;
}