Peter算法小课堂—简单建模(2)

2023-12-15 00:12

本文主要是介绍Peter算法小课堂—简单建模(2),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

太戈编程736题

题目描述:

你是一只汪星人,地球毁灭后你回到了汪星,这里每天有n个小时,你需要为自己选择正好连续的m小时作为每天睡眠的时间。从凌晨开始,第i小时内的睡眠质量为xi,请问经过选择后,你的睡眠质量总和最大是多少?

法1 断环+拉直+克隆

图示:

首先,这道题不是一般的前缀和问题,因为尾指针可以指向首指针。这个方法是普通方法,先拉直,再把数组复制一遍(所以数组至少要开两倍),然后算前缀和,最后扫一遍m+1到2*n,算差分最大值。写代码八

cin>>n>>m;
for(int i=1;i<=n;i++) cin>>x[i];
for(int i=n+1;i<=n*2;i++) x[i]=x[i-n];
s[0]=0;
for(int i=1;i<=n*2;i++) s[i]=s[i-1]+x[i];
int ans=s[m];
for(int i=m+1;i<=n*2;i++)ans=max(ans,s[i]-s[i-m]);
cout<<ans<<endl;

法2 滑动窗口

 

#include <bits/stdc++.h>
using namespace std;
int n,m;
int x[200009];
int cur,ans;
int main(){freopen("dog.in","r",stdin);freopen("dog.out","w",stdout);cin>>n>>m;for(int i=1;i<=n;i++){cin>>x[i];x[i+n]=x[i];}for(int i=1;i<=m;i++) cur+=x[i];ans=cur;for(int i=2;i<=n;i++){int cur=cur-x[i-1]+x[i+m-1];ans=max(cur,ans);}cout<<ans<<endl;return 0;
}

就是一个滑动窗口,看起来比法1简洁

法3 首位情况分类

图示:

 

那么,先正常前缀和,再m-1次特判。

cin>>n>>m;
for(int i=1;i<=n;i++) cin>>x[i];
for(int i=1;i<=n;i++) s[i]=s[i-1]+x[i];
int ans=s[m];
for(int i=m+1;i<=n;i++)ans=max(ans,s[i]-s[i-m]);
for(int i=1;i<=m-1;i++)ans=max(ans,s[i]+s[n]-s[n-m+i]);
cout<<ans<<endl;

法4 循环单链表(数据结构)

因为这一个数据结构我没讲过,所以……我来给大家梳理一遍代码。先来看普通单链表八

结构体指针-CSDN博客

节点函数

typedef struct _node
{int data;struct _node *next;
}node;

创造链表

struct node *create(int n)
{node *head;node *tail;node *h;head=tail=(node*)(malloc)(sizeof(node));h=head;node *p;int i=n;int d=0;cout<<"Please input the intergers."<<endl;for(i=n;i>0;i--){p=(node*)(malloc)(size(node));cin>>d;p->data=d;p->next=NULL;tail->next=p;tail=p;}tail->next=h;return h;
}

 链表查找函数

struct node *search(node *head,node *s,int x){int y;while(s!=head){y=s->data;if(x==y) return s;else s=s->next;}
}

常见使用

int main(){int n;cin>>n;node *prt;prt=create(n);node *first;first=prt->next;node *pr;pr=first;while(first!=prt){cout<<first->data<<" ";first=first->next;}int number;node *num;cout<<endl;cin>>number;num=search(prt,pr,number);cout<<num->data;return 0;
}

 嗯……这个方法自己尝试八,比较有风险,但是如果用对了就很酷。

太戈编程650题

题目描述:

你作为校长,正在筹办校园开放日,希望邀请学生和家长来参观,期间有n个公开课在不同教室开展。第i个公开课从时刻si分钟到时刻ti分钟,需要摆放xi把椅子。椅子从一个教室搬到另一个教室需要5分钟(假设人手足够多,不管搬几把椅子都是这个时间)。请问至少需要几把椅子?

这题用差分真的真的很好做!

差分的话,想到有些小朋友还不懂,我来讲一下吧。差分有什么用呢?差分可以使一个数组S中一段区间每个元素加上常数C。比如说:有任意一个数组S,区间[l,r]内每一个元素均加上常数j。若用暴力,枚举[l,r]中每一个元素,加j,时间复杂度为O(n),显然有更快的算法。若用差分,假设S的差分数组为A,则在A中标记第l个加j,第r+1个减j,这时再把差分数组化成前缀和数组,即可得到目标数组,时间复杂度O(1)

所以……上代码八

cin>>n;
for(int i=1;i<=n;i++){cin>>a>>b>>x;d[a]+=x;d[b+5]-=x;
}
for(int i=1;i<R;i++) s[i]=s[i-1]+d[i];
cout<<*max_element(s+1,s+1+n);

拓展:太戈编程2667

数据分类

int main(){freopen("training.in","r",stdin);freopen("training.out","w",stdout);input();if(n<=1000&&m<=1000) solveBF();else solve();return 0;
}

 BF

void solveBF(){for(l i=1;i<=m;i++){ll l,r;cin>>l>>r;ll ans=0;for(ll j=l;j<=r;++j) ans+=h[j]*(j-l+1);cout<<ans<<" ";}
}

满分解法

 

数学不好的请退出……

void solve(){for(ll i=1;i<=n;i++){s[i]=s[i-1]+h[i];g[i]=g[i-1]+h[i]*i;}for(ll i=1;i<=m;++i){ll l,r;cin>>l>>r;ll ans=g[r]-g[l-1]-(s[r]-s[l-1])*(l-1);cout<<ans<<" ";}
}

 希望这些对大家有用,三连必回。

这篇关于Peter算法小课堂—简单建模(2)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Java中的雪花算法Snowflake解析与实践技巧

《Java中的雪花算法Snowflake解析与实践技巧》本文解析了雪花算法的原理、Java实现及生产实践,涵盖ID结构、位运算技巧、时钟回拨处理、WorkerId分配等关键点,并探讨了百度UidGen... 目录一、雪花算法核心原理1.1 算法起源1.2 ID结构详解1.3 核心特性二、Java实现解析2.

基于Python实现一个简单的题库与在线考试系统

《基于Python实现一个简单的题库与在线考试系统》在当今信息化教育时代,在线学习与考试系统已成为教育技术领域的重要组成部分,本文就来介绍一下如何使用Python和PyQt5框架开发一个名为白泽题库系... 目录概述功能特点界面展示系统架构设计类结构图Excel题库填写格式模板题库题目填写格式表核心数据结构

C/C++ chrono简单使用场景示例详解

《C/C++chrono简单使用场景示例详解》:本文主要介绍C/C++chrono简单使用场景示例详解,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友... 目录chrono使用场景举例1 输出格式化字符串chrono使用场景China编程举例1 输出格式化字符串示

windows和Linux安装Jmeter与简单使用方式

《windows和Linux安装Jmeter与简单使用方式》:本文主要介绍windows和Linux安装Jmeter与简单使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录Windows和linux安装Jmeter与简单使用一、下载安装包二、JDK安装1.windows设

使用雪花算法产生id导致前端精度缺失问题解决方案

《使用雪花算法产生id导致前端精度缺失问题解决方案》雪花算法由Twitter提出,设计目的是生成唯一的、递增的ID,下面:本文主要介绍使用雪花算法产生id导致前端精度缺失问题的解决方案,文中通过代... 目录一、问题根源二、解决方案1. 全局配置Jackson序列化规则2. 实体类必须使用Long封装类3.

Springboot实现推荐系统的协同过滤算法

《Springboot实现推荐系统的协同过滤算法》协同过滤算法是一种在推荐系统中广泛使用的算法,用于预测用户对物品(如商品、电影、音乐等)的偏好,从而实现个性化推荐,下面给大家介绍Springboot... 目录前言基本原理 算法分类 计算方法应用场景 代码实现 前言协同过滤算法(Collaborativ

openCV中KNN算法的实现

《openCV中KNN算法的实现》KNN算法是一种简单且常用的分类算法,本文主要介绍了openCV中KNN算法的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录KNN算法流程使用OpenCV实现KNNOpenCV 是一个开源的跨平台计算机视觉库,它提供了各

springboot+dubbo实现时间轮算法

《springboot+dubbo实现时间轮算法》时间轮是一种高效利用线程资源进行批量化调度的算法,本文主要介绍了springboot+dubbo实现时间轮算法,文中通过示例代码介绍的非常详细,对大家... 目录前言一、参数说明二、具体实现1、HashedwheelTimer2、createWheel3、n

使用Python开发一个简单的本地图片服务器

《使用Python开发一个简单的本地图片服务器》本文介绍了如何结合wxPython构建的图形用户界面GUI和Python内建的Web服务器功能,在本地网络中搭建一个私人的,即开即用的网页相册,文中的示... 目录项目目标核心技术栈代码深度解析完整代码工作流程主要功能与优势潜在改进与思考运行结果总结你是否曾经

Mysql表的简单操作(基本技能)

《Mysql表的简单操作(基本技能)》在数据库中,表的操作主要包括表的创建、查看、修改、删除等,了解如何操作这些表是数据库管理和开发的基本技能,本文给大家介绍Mysql表的简单操作,感兴趣的朋友一起看... 目录3.1 创建表 3.2 查看表结构3.3 修改表3.4 实践案例:修改表在数据库中,表的操作主要