首页 > 学院 > 开发设计 > 正文

汉诺塔ix C语言

2019-11-11 07:45:54
字体:
来源:转载
供稿:网友

看了许多思路,突然想到一种方法

1是1 3 5 7 9

2是2 6 10 

3是4 12 20

n就是 2^n-1   2^n-1+2^n  2^n-1+2^n+2^n

代码贴在下面

#include<stdio.h>#include<math.h>int main(void){	int n,m,i;	while(scanf("%d%d",&n,&m),n+m){		if(m%2==1) PRintf("%d/n",1);		else for(i=2;i<=n;i++){			if((m+(int)pow(2,i-1))%(int)pow(2,i)==0){				printf("%d/n",i);				break;			}		}	}	return 0;}


上一篇:位运算例题4

下一篇:求最长递增子串

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表