社区讨论

P1588发布一种更优化写法,直接分情况讨论走即可!!!

P1588[USACO07OPEN] Catch That Cow S参与者 2已保存回复 1

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
1 条
当前快照
1 份
快照标识符
@m2027t0q
此快照首次捕获于
2024/10/08 14:28
去年
此快照最后确认于
2024/10/08 19:29
去年
查看原帖
CPP
#include <iostream>
using namespace std;
int main() {
	int n,k,t,ans;
	cin>>t;
	while(t--){
        cin >> n >> k;
        if(n>=k){	//如果n>=k,结果就是n-k 
        	cout<<n-k<<"\n";
        	continue;
		} 
        ans=0;	//步数归零
		//让k向n靠拢,贪心策略。分情况讨论得出结果 
        while(1){
    		if(k/2<n){	//如果n在(k/2,k),选择两者短的路程走 
    			ans+=min(n-k/2+1,k-n);
    			break;
    		}else if(k%4==3&&k/4<n){//如果n在(k/4,k/2],并且k+1是4的倍数,选择两种短的路程走 
    			ans+=min(k/2-n+2,n-(k+1)/4+3);
    			break;
    		}else if(k%4==3){	//如果n在(0,k/4],k+1 
    			k++;
    			ans++;
    		}else if(k%4==1){	//如果n在(0,k/2],k-1是4的倍数,k-1 
    			k--;
    			ans++;
    		}else{				//如果n在(0,k/2],k是偶数,k除以2 
    			k/=2;
    			ans++;
    		}
    	}
    	cout<<ans<<"\n";
	}
    return 0;
}

回复

1 条回复,欢迎继续交流。

正在加载回复...