雀士分麻将( 北京理工大学2019年计算机学院小学期程序设计方法与实践)

本文主要是介绍雀士分麻将( 北京理工大学2019年计算机学院小学期程序设计方法与实践),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

一年一度的日麻大赛结束啦,作为本场比赛的主裁判汪次郎要给大家发奖品了

一姬、二阶堂美树、三上千织等雀士排成一排,等待发奖品。本届比赛的奖品为麻将,发奖规则如下:

  • 每个人都有一个自己的分数ai,代表本次比赛中获得的成绩。
  • 每个选手至少可以获得1张麻将作为奖励。
  • 如果两位选手站位相邻,积分高的选手一定比积分低的选手获得的麻将多。

作为主裁判的汪次郎,当然想减少在奖品上的开销,现在他已经知道了每个人的分数,请你帮他计算一下最少他需要多少麻将来发奖。

Input
输入数据共2行,第一行包括一个整数n(1≤n≤105)。

接下来n行,每行1个整数a1,a2,⋯,an(1≤ai≤105),其中第i个数表示站在第i位的人的积分。

Output
输出共一行,表示主裁判汪次郎最少发的麻将数

Input

3
1
2
2

Output

4

思路:从前 往后跑一边,在从后往前跑一边。

AC的代码:

#include<bits/stdc++.h>using namespace std;
#define int long long
int a[210000];
int arr[250000];
signed  main(){int n;cin>>n;for(int i=1;i<=n;i++){scanf("%lld",&a[i]);}arr[1]=1;for(int i=2;i<=n;i++){if(a[i]>a[i-1]){arr[i]=arr[i-1]+1;}else{arr[i]=1;}}for(int i=n;i>=2;i--){if(a[i]>=a[i-1]){continue;}else{if(arr[i-1]<=arr[i]) arr[i-1]=arr[i]+1;}}int ans=0;for(int i=1;i<=n;i++){ans+=arr[i];}printf("%lld\n",ans);return 0;
}

 

转载于:https://www.cnblogs.com/pengge666/p/11494109.html

这篇关于雀士分麻将( 北京理工大学2019年计算机学院小学期程序设计方法与实践)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/409621

相关文章

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

破茧 JDBC:MyBatis 在 Spring Boot 中的轻量实践指南

《破茧JDBC:MyBatis在SpringBoot中的轻量实践指南》MyBatis是持久层框架,简化JDBC开发,通过接口+XML/注解实现数据访问,动态代理生成实现类,支持增删改查及参数... 目录一、什么是 MyBATis二、 MyBatis 入门2.1、创建项目2.2、配置数据库连接字符串2.3、入

Python安装Pandas库的两种方法

《Python安装Pandas库的两种方法》本文介绍了三种安装PythonPandas库的方法,通过cmd命令行安装并解决版本冲突,手动下载whl文件安装,更换国内镜像源加速下载,最后建议用pipli... 目录方法一:cmd命令行执行pip install pandas方法二:找到pandas下载库,然后

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.

Linux系统中查询JDK安装目录的几种常用方法

《Linux系统中查询JDK安装目录的几种常用方法》:本文主要介绍Linux系统中查询JDK安装目录的几种常用方法,方法分别是通过update-alternatives、Java命令、环境变量及目... 目录方法 1:通过update-alternatives查询(推荐)方法 2:检查所有已安装的 JDK方

SQL Server安装时候没有中文选项的解决方法

《SQLServer安装时候没有中文选项的解决方法》用户安装SQLServer时界面全英文,无中文选项,通过修改安装设置中的国家或地区为中文中国,重启安装程序后界面恢复中文,解决了问题,对SQLSe... 你是不是在安装SQL Server时候发现安装界面和别人不同,并且无论如何都没有中文选项?这个问题也

Java Thread中join方法使用举例详解

《JavaThread中join方法使用举例详解》JavaThread中join()方法主要是让调用改方法的thread完成run方法里面的东西后,在执行join()方法后面的代码,这篇文章主要介绍... 目录前言1.join()方法的定义和作用2.join()方法的三个重载版本3.join()方法的工作原

在Java中使用OpenCV实践

《在Java中使用OpenCV实践》用户分享了在Java项目中集成OpenCV4.10.0的实践经验,涵盖库简介、Windows安装、依赖配置及灰度图测试,强调其在图像处理领域的多功能性,并计划后续探... 目录前言一 、OpenCV1.简介2.下载与安装3.目录说明二、在Java项目中使用三 、测试1.测

MyBatis-Plus 自动赋值实体字段最佳实践指南

《MyBatis-Plus自动赋值实体字段最佳实践指南》MyBatis-Plus通过@TableField注解与填充策略,实现时间戳、用户信息、逻辑删除等字段的自动填充,减少手动赋值,提升开发效率与... 目录1. MyBATis-Plus 自动赋值概述1.1 适用场景1.2 自动填充的原理1.3 填充策略

在MySQL中实现冷热数据分离的方法及使用场景底层原理解析

《在MySQL中实现冷热数据分离的方法及使用场景底层原理解析》MySQL冷热数据分离通过分表/分区策略、数据归档和索引优化,将频繁访问的热数据与冷数据分开存储,提升查询效率并降低存储成本,适用于高并发... 目录实现冷热数据分离1. 分表策略2. 使用分区表3. 数据归档与迁移在mysql中实现冷热数据分