Add All -uva优先队列的应用

2024-09-08 00:18
文章标签 应用 队列 优先 add uva

本文主要是介绍Add All -uva优先队列的应用,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目的解法属于贪心,因为cost=a1+a2,所以要保证每次的cost最小,所以说,每次将队列中最小的两个相加,得出来的数放入队列中,再取2个最小的相加,直到全部加完,所以这就涉及了一个取2个最小数的问题,我说一下我一开始的做法
#include<stdio.h>
#include<iostream>
#include<stdlib.h>
using namespace std;
#define MAX_SIZE 10000 + 10
int cmp(const void *a,const void *b)
{return *(int*)a-*(int*)b;
}
int main()
{int i,n;for(;scanf("%d",&n);){int num[MAX_SIZE]={0};int temp=0,sum=0;int front=0,back=n-1;if(!n) break;for(i=0;i<n;i++)scanf("%d",&num[i]);while(front<back) /*只有一个数的时候程序结束*/{qsort(num+front,back-front+1,sizeof(num[0]),cmp);/*每次都要排序*/temp=num[front]+num[front+1];/*printf("%d\n",front);printf("%d + %d = %d\n",num[front],num[front+1],temp);*/sum+=temp;front+=2;back++;num[back]=temp;}printf("%d\n",sum);}return 0;
}

这种算法是超时的,因为我每次都对队列进行了一次排序

下面是使用优先队列的算法

#include<stdio.h>
#include<iostream>
#include<stdlib.h>
#include<queue>
#include<algorithm>
#include<vector>
using namespace std;
int main()
{int i,n;priority_queue < int,vector<int>,greater<int> >q;/*优先队列*/while(scanf("%d",&n)&&n){int temp,sum=0;/*printf("%d\n",n);*/for(i=0;i<n;i++){scanf("%d",&temp);q.push(temp);}while(!q.empty()){/*printf("%d\n",sum);*/int n1,n2,n3;n1=q.top();q.pop();if(q.empty())break;n2=q.top();q.pop();n3=n1+n2;sum+=n3;q.push(n3);/*printf("%d\n",sum);*/}printf("%d\n",sum);}return 0;
}

优先队列一开始我也不会,之后上网查了一下别人的资料,自己写出来了

参考资料:http://blog.csdn.net/shuangde800/article/details/7327759

这篇关于Add All -uva优先队列的应用的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

如何通过Python实现一个消息队列

《如何通过Python实现一个消息队列》这篇文章主要为大家详细介绍了如何通过Python实现一个简单的消息队列,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录如何通过 python 实现消息队列如何把 http 请求放在队列中执行1. 使用 queue.Queue 和 reque

解读Redis秒杀优化方案(阻塞队列+基于Stream流的消息队列)

《解读Redis秒杀优化方案(阻塞队列+基于Stream流的消息队列)》该文章介绍了使用Redis的阻塞队列和Stream流的消息队列来优化秒杀系统的方案,通过将秒杀流程拆分为两条流水线,使用Redi... 目录Redis秒杀优化方案(阻塞队列+Stream流的消息队列)什么是消息队列?消费者组的工作方式每

5分钟获取deepseek api并搭建简易问答应用

《5分钟获取deepseekapi并搭建简易问答应用》本文主要介绍了5分钟获取deepseekapi并搭建简易问答应用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需... 目录1、获取api2、获取base_url和chat_model3、配置模型参数方法一:终端中临时将加

JavaScript中的isTrusted属性及其应用场景详解

《JavaScript中的isTrusted属性及其应用场景详解》在现代Web开发中,JavaScript是构建交互式应用的核心语言,随着前端技术的不断发展,开发者需要处理越来越多的复杂场景,例如事件... 目录引言一、问题背景二、isTrusted 属性的来源与作用1. isTrusted 的定义2. 为

Python调用另一个py文件并传递参数常见的方法及其应用场景

《Python调用另一个py文件并传递参数常见的方法及其应用场景》:本文主要介绍在Python中调用另一个py文件并传递参数的几种常见方法,包括使用import语句、exec函数、subproce... 目录前言1. 使用import语句1.1 基本用法1.2 导入特定函数1.3 处理文件路径2. 使用ex

Redis延迟队列的实现示例

《Redis延迟队列的实现示例》Redis延迟队列是一种使用Redis实现的消息队列,本文主要介绍了Redis延迟队列的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习... 目录一、什么是 Redis 延迟队列二、实现原理三、Java 代码示例四、注意事项五、使用 Redi

将Python应用部署到生产环境的小技巧分享

《将Python应用部署到生产环境的小技巧分享》文章主要讲述了在将Python应用程序部署到生产环境之前,需要进行的准备工作和最佳实践,包括心态调整、代码审查、测试覆盖率提升、配置文件优化、日志记录完... 目录部署前夜:从开发到生产的心理准备与检查清单环境搭建:打造稳固的应用运行平台自动化流水线:让部署像

Linux中Curl参数详解实践应用

《Linux中Curl参数详解实践应用》在现代网络开发和运维工作中,curl命令是一个不可或缺的工具,它是一个利用URL语法在命令行下工作的文件传输工具,支持多种协议,如HTTP、HTTPS、FTP等... 目录引言一、基础请求参数1. -X 或 --request2. -d 或 --data3. -H 或

在Ubuntu上部署SpringBoot应用的操作步骤

《在Ubuntu上部署SpringBoot应用的操作步骤》随着云计算和容器化技术的普及,Linux服务器已成为部署Web应用程序的主流平台之一,Java作为一种跨平台的编程语言,具有广泛的应用场景,本... 目录一、部署准备二、安装 Java 环境1. 安装 JDK2. 验证 Java 安装三、安装 mys

Python中构建终端应用界面利器Blessed模块的使用

《Python中构建终端应用界面利器Blessed模块的使用》Blessed库作为一个轻量级且功能强大的解决方案,开始在开发者中赢得口碑,今天,我们就一起来探索一下它是如何让终端UI开发变得轻松而高... 目录一、安装与配置:简单、快速、无障碍二、基本功能:从彩色文本到动态交互1. 显示基本内容2. 创建链