Educational Codeforces Round 133 (Rated for Div. 2)

本来也没啥的这A题也不改花多久时间 大家都在用暴力我来给出O(1)的解法 确实不容易写出这的时候已经崩溃了放上一张图片共参考请添加图片描述
说我菜吧确实…

再讲解也下吧
呃。。。。。
再讲解也下吧:

题目就是在一个数轴上有一个小人她站在原点上然后他需要去第n个点,每次可以向右(向左)2个或3个单位 问最快多少步可以到达点n

需要解决的问题:

  1. 负数怎么到达
  2. 有几种情况最快

解决的方法:
3. 套用abs函数即n=abs(n);
4. 共有5种解决方法:(这四种最后直接区min)
5.

  1. 每次都行走两格(n/2)
  2. 先走三格在走两格最后在把剩余的一格走了(就是shit函数)
  3. 直接走三格
  4. 先走两格再走三格
  5. 走两格再走剩余的

还有一个特判(好像不要也行)「只要走一个时候输出2」

废话不多逼逼第一题代码:

#include <bits/stdc++.h>
using namespace std;
int shit(int n){
    int tot=0;
    tot+=(n/3);//2
    int t3=tot;
    int t2=((n-(3*tot))/2);
    tot+=(n-(3*tot))/2;
    tot+=n-(t3*3+t2*2);
    return tot;
}
int main(){
    int t;
    cin>>t;
   while(t--){
        int n;
        cin>>n;
        int num;
        n=abs(n);
        if(n==1){
            cout<<2<<endl;
            continue;
        }
        if(n%3==0){
            cout<<(n/3)+(n%3)<<endl;
        }
        else{
       
         num=min(shit(n),(n/2));
         int num2=min(((n/2)+(n%2)),((n/2)+(n%3)));
        cout<<min(num,num2)<<endl;
            
        }
        
    }
    return 0;
}

第二题也不难现在去写了拜拜

求点赞(肯定没人关注收藏)鼓励一下吧

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值