牛客练习赛86 反思与总结 (含C题题解)

牛客练习赛86

比赛链接

复盘与分析

这一场和上一次的cf相比有所进步。

在做题的时候注意到了,和cf相比牛客的题目是中文而且非常的简单易读,基本读一遍就知道怎么解释样例了;但是,cf就非常吃力,基本上多半读题读上好久,而且容易遗漏关键信息。

所以,读题也是今后要提升的一方面 英语辣鸡的救赎

在这场中,C题是没能做出来的,赛后看了看题解,发现想法和方向基本是对的。

但是,中间的一些预处理做的还是不好,没有像提供题解的大佬的高水平,导致自己预处理之后,需要非常多的特判。

C题需要一些二分的知识

STL有关于二分函数的用法,下面的文章说了一些的非常简易的做法
STL的二分查找

C题题解

题目概述:
原题目
拿到题目的第一感觉就是数据量非常大,时间复杂度的要求比较严格,o(n)都过不了,基本就是o(logN)

加上要在数组中查找数据,我就先确定了是二分,预处理,最后进行一步数学公式的计算出答案

只是可惜自己预处理,处理了个寂寞

预处理步骤:
首先,需要用一个数组a来存储钞票的不同的面额

其次,要用数组s存储不同面额-1的金额,因为在满足一定条件时,这个金额所兑换的纸币张数会是最多的

最后,用数组k存储s数组金额所对应的张数

一定条件:
倘若现在的最大金额为M,
当M >= m && (m - s[i]) % s[i + 1] == 0时
就取出m元,此时对应的张数为ans = (m - s[i])/a[i + 1] + k[i] 为最大

如果感觉不理解可以仔细想一想,这个还是很好理解的

代码:

#include <iostream>
#include <algorithm>
#define ll long long

using namespace std;
const int maxn = 2e5 + 10;
int n, q;
ll a[maxn], x;
ll k[maxn], s[maxn];

int main(){
	ios::sync_with_stdio(false);
	
	cin >> n;
	for (int i = 1; i <= n; i++)
		cin >> a[i];
		
	for (int i = 1;i < n; i++) {
		k[i] = (a[i + 1] - s[i - 1] - 1) / a[i];
		s[i] = s[i - 1] + k[i]*a[i];
		k[i] += k[i-1];
	}
	
	cin >> q;
	
	while (q--) {
		cin >> x;
		
		int p = upper_bound(s, s + n, x) - s - 1;
		ll m = (x - s[p]) / a[p + 1];
		
		cout << s[p] + m*a[p + 1] << " " << k[p] + m << endl;
	}

	return 0;
}

可惜,没A出C题感觉还是很难受,,,

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面只是目标目录 ├─第1章-Shiro权限实战课程介绍 │ 1-1Shiro权限实战课程介绍.mp4 │ 1-2权限控制和初学JavaWeb处理访问权限控制.mp4 │ ├─第2章-大话权限框架核心知识ACL和RBAC │ 2-1权限框架设计之ACL和RBAC讲解.mp4 │ 2-2主流权限框架介绍和技术选型讲解.mp4 │ ├─第3章-ApacheShiro基础概念知识和架构讲解 │ 3-1Shiro核心知识之架构图交互和四大模块讲解.mp4 │ 3-2用户访问Shrio权限控制运行流程和常见概念讲解.mp4 │ ├─第4章-Springboot2.x整合ApacheShiro快速上手实战 │ 4-1SpringBoot2.x整合Shiro.mp4 │ 4-2快速上手之Shiro认证和授权流程实操上集.mp4 │ 4-3Shiro认证和授权流程和常用API梳理下集.mp4 │ ├─第5章-详细讲解ApacheShirorealm实战 │ 5-1Shiro安全数据来源之Realm讲解.mp4 │ 5-2快速上手之Shiro内置IniRealm实操.mp4 │ 5-3快速上手之Shiro内置JdbcRealm实操.mp4 │ 5-4ApacheShiro自定义Readl实战.mp4 │ 5-5深入Shiro源码解读认证授权流程.mp4 │ ├─第6章-Shiro权限认证Web案例知识点讲解 │ 6-1Shiro内置的Filter过滤器讲解.mp4 │ 6-2Shiro的Filter配置路径讲解.mp4 │ 6-3Shiro数据安全之数据加解密.mp4 │ 6-4Shiro权限控制注解和编程方式讲解.mp4 │ 6-5Shiro缓存模块讲解.mp4 │ 6-6ShiroSession模块讲解.mp4 │ ├─第7章-ApacheShiro整合SpringBoot2.x综合案例实战 │ 7-10使用ShiroLogout和加密处理.mp4 │ 7-1Shiro整合SpringBoot2.x案例实战介绍.mp4 │ 7-2基于RBAC权限控制实战之Mysql数据库设计.mp4 │ 7-3SpringBoot2.x项目框架和依赖搭建.mp4 │ 7-4案例实战之权限相关服务接口开发.mp4 │ 7-5案例实战之用户角色权限多对多关联查询SQL.mp4 │ 7-6案例实战自定义CustomRealm实战.mp4 │ 7-7项目实战之ShiroFilterFactoryBean配置实战.mp4 │ 7-8前后端分离自定义SessionManager验证.mp4 │ 7-9API权限拦截验证实战.mp4 │ ├─第8章-权限控制综合案例实战进阶 │ 8-1实战进阶之自定义ShiroFilter过滤器上集.mp4 │ 8-2实战进阶之自定义ShiroFilter过滤器下集.mp4 │ 8-3性能提升之Redis整合CacheManager.mp4 │ 8-4性能提升之Redis整合SessionManager.mp4 │ 8-5ShiroConfig常用bean类配置.mp4 │ ├─第9章-大话分布式应用的鉴权方式 │ 9-1单体应用到分布式应用下的鉴权方式介绍.mp4 │ 9-2Shiro整合SpringBoot下自定义SessionId.mp4 │ ├─第10章-Shiro课程总结 │ 10-1Apacheshiro从入门到高级实战课程总结.mp4 │ 10-2高级工程师到架构师-解决问思路+学习方法.mp4 │ └─课件资料.zip

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值