g.cpp

来自「ACM训练题解 最新版 共8题 ACM训练题解 最新版 共8题」· C++ 代码 · 共 19 行

CPP
19
字号
// Problem G
// http://acm.uva.es/p/v109/10940.html
// Solution by semiconductor
#include <stdio.h>
int solve(int n,bool f)
{
	if(n==1)return 1;
	if(f)return solve(n>>1,(n&1)==0)<<1;
	else return (solve((n+1)>>1,(n&1)==1)<<1)-1;
}

int main()
{
	int n;
	while(scanf("%d",&n),n)
		printf("%d\n",solve(n,true));
	return 0;
}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?