3.13~3.14学习总结

cf补了A题和B题,

A:https://codeforces.com/contest/1804/problem/A

A题的思路,是先到达对角线,例如(2,3)我们先到达(2,2)点,这个时候是不需要休息的,可以直接接着到达(2,3),同理不用休息也可以直接到达(3,2),但是不能不休息到达(2,4)和(4,2),有点贪心的思想在里面,先不休息到达离终点最近的地方。我们归纳一下可以得到结论

((abs(a)+abs(b))+abs((abs(a)-abs(b)))-1);

#include<iostream>
#include<cmath>
using namespace std;
int main()
{
    int k;
    cin>>k;
    while(k--)
    {
        int a,b;
        cin>>a>>b;
        int ans;
        if(abs(a)-abs(b)!=0)
        {
            ans=((abs(a)+abs(b))+abs((abs(a)-abs(b)))-1);
            cout<<ans<<endl;
        }
        else cout<<abs(a)+abs(b)<<endl;
    }
}

B:https://codeforces.com/contest/1804/problem/B

思路:利用双指针一个指向患者的遍历,一个指向等待的患者。

if(a[i]-a[j]-w>d||i-j+1>k)这个判断语句是关键,前判断条件为,a[j]到达的时刻打开包装,快过期的时候用掉(同时满足患者等待的最长时间),同样有点贪心思想,患者等最久的时间,结果会最优,后判断条件为判断该包装是否用完。

#include<iostream>
using namespace std;
int a[200005];
int main() 
{
    int T,n,k,d,w;
    cin>>T;
    while(T--)
    {
        cin>>n>>k>>d>>w;
        int ans=0;
        for(int i=0;i<n;i++)
        {
            cin>>a[i];
        }
        int j=0;
        for(int i=0;i<n;i++)
        {
            if(a[i]-a[j]-w>d||i-j+1>k)
            {
                ans++;
                j=i;
            }
        }
        cout<<ans+1<<endl;
    }
}

下载安装了jdk,idea,git,navicat,学习了Java基础语法(变量,输入,输出)稍微总结归纳了一下和c的变量的一些区分之处。

想通过力扣上的刷题复习之前学过的算法,查漏补缺一下,以下是完成情况(第二天任务差一道,晚上加班补好)

C - Find The Multiple

https://vjudge.net/contest/547627#problem/C

第一眼觉得是个数学题,然后找了一下规律,发现我找不到,然后看了眼题组,搜索,噢,然后尝试了bfs,写到要开队列大小的时候,1生2,2生4,4生8,最大有2的99次方,装不下咋办,我想到了用c++的循环队列,一提交,内存超限,随后使用了dfs。再换了语言之后可算过了。

A - Dungeon Master

https://vjudge.net/contest/547627#problem/A

模板bfs三维题,找bug找了好久,后面受高人指点,原来是book数组没赋值(以后要更加注意赋初值)。

小结:加班复习算法的任务题写完。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

卡卡卡卡罗特

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值