PAT 1044 Shopping in Mars[二分][难]
1044 Shopping in Mars(25 分)
Shopping in Mars is quite a different experience. The Mars people pay by chained diamonds. Each diamond has a value (in Mars dollars M$). When making the payment, the chain can be cut at any position for only once and some of the diamonds are taken off the chain one by one. Once a diamond is off the chain, it cannot be taken back. For example, if we have a chain of 8 diamonds with values M$3, 2, 1, 5, 4, 6, 8, 7, and we must pay M$15. We may have 3 options:
- Cut the chain between 4 and 6, and take off the diamonds from the position 1 to 5 (with values 3+2+1+5+4=15).
- Cut before 5 or after 6, and take off the diamonds from the position 4 to 6 (with values 5+4+6=15).
- Cut before 8, and take off the diamonds from the position 7 to 8 (with values 8+7=15).
Now given the chain of diamond values and the amount that a customer has to pay, you are supposed to list all the paying options for the customer.
If it is impossible to pay the exact amount, you must suggest solutions with minimum lost.
Input Specification:
Each input file contains one test case. For each case, the first line contains 2 numbers: N (≤105), the total number of diamonds on the chain, and M (≤108), the amount that the customer has to pay. Then the next line contains N positive numbers D1⋯DN (Di≤103 for all i=1,⋯,N) which are the values of the diamonds. All the numbers in a line are separated by a space.
Output Specification:
For each test case, print i-j
in a line for each pair of i
≤ j
such that Di
+ ... + Dj
= M. Note that if there are more than one solution, all the solutions must be printed in increasing order of i
.
If there is no solution, output i-j
for pairs of i
≤ j
such that Di
+ ... + Dj
>M with (Di
+ ... + Dj
−M) minimized. Again all the solutions must be printed in increasing order of i
.
It is guaranteed that the total value of diamonds is sufficient to pay the given amount.
Sample Input 1:
16 15
3 2 1 5 4 6 8 7 16 10 15 11 9 12 14 13
Sample Output 1:
1-5
4-6
7-8
11-11
Sample Input 2:
5 13
2 4 5 7 9
Sample Output 2:
2-4
4-5
题目大意:给出一串数表示钻石的价值,并且给出m,如果有一连串钻石价值正好等于m,那么就输出这一串;如果没有正好相等的和,那么就输出那些>m,并且和m差值最小的!
//第一次提交这样,就是通过两层循环来做,
#include <iostream>
#include <vector>
#include <cmath>
using namespace std;
int dio[];
int main() {
int n,m;
cin>>n>>m;
for(int i=;i<n;i++){
cin>>dio[i];
}
bool flag=false;
for(int i=;i<n;i++){
int sum=;
for(int j=i;j<n;j++){
sum+=dio[j];
if(sum==m){
flag=true;
cout<<i+<<'-'<<j+<<'\n';break;
}
}
}
vector<int> vt;
if(!flag){//如果没有解。
int mini=;
for(int i=;i<n;i++){
int sum=;
for(int j=i;j<n;j++){
sum+=dio[j];
if(sum>m&&sum-m<mini){
vt.clear();
vt.push_back(i+);
vt.push_back(j+);
//cout<<i+1<<"="<<j+1<<" "<<sum<<'\n';
mini=sum-m;break;
}else if(sum>m&&sum-m==mini){
vt.push_back(i+);
vt.push_back(j+);
// cout<<i+1<<"+"<<j+1<<'\n';
break;
}
}
}
}
for(int i=;i<vt.size();i+=){
cout<<vt[i]<<'-'<<vt[i+]<<'\n';
}
return ;
}
//但是提交到牛客网上,
运行超时:您的程序未能在规定时间内运行结束,请检查是否循环有错或算法复杂度过大。
case通过率为40.00%
//顿时感觉凉凉。提交到pat上,2,3,5测试点运行超时。
代码来自:https://www.liuchuo.net/archives/2939
#include <iostream>
#include <vector>
using namespace std;
vector<int> sum, resultArr;
int n, m;
void Func(int i, int &j, int &tempsum) {//这个求的是从i到j的和。
//表面上是left,但是while里的if条件仍然只是>=m
int left = i, right = n;
while(left < right) {
int mid = (left + right) / ;
if(sum[mid] - sum[i-] >= m)
right = mid;//必须是=mid,如果是mid-1,那很有可能和就不够了。
else
left = mid + ;
}
j = right;//传引用的话,是不用return的,
tempsum = sum[j] - sum[i-];
}
int main() {
scanf("%d%d", &n, &m);
sum.resize(n+);
for(int i = ; i <= n; i++) {
scanf("%d", &sum[i]);
sum[i] += sum[i-];//这是前缀和?
}
int minans = sum[n];
for(int i = ; i <= n; i++) {
int j, tempsum;
Func(i, j, tempsum);//直接传引用。
if(tempsum > minans) continue;//感觉这一句不用吧,肯定不会大于的。
//明白了,这个在i=1第一次循环的时候是没用,但是minans更新之后就有用了。
//判断>当前的都不选择。
if(tempsum >= m) {
if(tempsum < minans) {
resultArr.clear();
minans = tempsum;
}
resultArr.push_back(i);
resultArr.push_back(j);
}
}
for(int i = ; i < resultArr.size(); i += )
printf("%d-%d\n", resultArr[i], resultArr[i+]);
return ;
}
//学习了,不用直接去找是否有=m,或者没有等于的,都一样的方式去遍历查找。
1.当程序正常超时时,需要考虑二分法。
2.使用引用传值,减少函数调用时间。
3.这里的mid求的不是到left的和,而是到i的和!和往常的不一样。
//这个二分我感觉确实挺难的,相不到,
代码来自:https://www.cnblogs.com/chenxiwenruo/p/6677802.html
#include <iostream>
#include <cstdio>
#include <algorithm>
#include <string.h>
#include <vector>
#define INF 0x3f3f3f3f
using namespace std; const int maxn=+;
int n,m;
int diamond[maxn];
struct Ans{
int i,j;
}; vector<Ans> ans;
int main()
{
scanf("%d %d\n",&n,&m);
for(int i=;i<=n;i++)
scanf("%d",&diamond[i]);
int minlost=INF;
Ans tmp;
int sum=;
int start=;
for(int i=;i<=n;i++){
sum+=diamond[i];
//printf("%d %d %d %d %d\n",start,i,sum,sum-m,minlost);
if(sum<m)
continue;
if(sum-m<=minlost){
if(sum-m<minlost){
ans.clear();
minlost=sum-m;
}
tmp.i=start;
tmp.j=i;
ans.push_back(tmp);
}
if(sum>=m && start<i){//这里是在做什么?
sum-=diamond[i];//明白了,-钻石i的值,和钻石start的值,
i--;//如果减去diamond[i],并且减去start的值,那么总和肯定小于m,那么
sum-=diamond[start];//肯定要就着i往下加了。
start++;//目前的sum肯定达不到m,所以肯定需要往后加。
printf("%d\n",sum);
}
}
for(int i=;i<ans.size();i++){
printf("%d-%d\n",ans[i].i,ans[i].j);
}
return ;
}
//这个也写得很好,但是我有点不太理解。
// 但是接着说上述二分方法的话,也就是原来二分,求和之后二分的方法。
PAT 1044 Shopping in Mars[二分][难]的更多相关文章
- PAT 1044. Shopping in Mars
#include <cstdio> #include <cstdlib> #include <vector> #include <climits> #i ...
- PAT 甲级 1044 Shopping in Mars (25 分)(滑动窗口,尺取法,也可二分)
1044 Shopping in Mars (25 分) Shopping in Mars is quite a different experience. The Mars people pay ...
- 1044 Shopping in Mars (25 分)
1044 Shopping in Mars (25 分) Shopping in Mars is quite a different experience. The Mars people pay b ...
- PAT 甲级 1044 Shopping in Mars
https://pintia.cn/problem-sets/994805342720868352/problems/994805439202443264 Shopping in Mars is qu ...
- PAT Advanced 1044 Shopping in Mars (25) [⼆分查找]
题目 Shopping in Mars is quite a diferent experience. The Mars people pay by chained diamonds. Each di ...
- 1044 Shopping in Mars (25分)(二分查找)
Shopping in Mars is quite a different experience. The Mars people pay by chained diamonds. Each diam ...
- 1044 Shopping in Mars
Shopping in Mars is quite a different experience. The Mars people pay by chained diamonds. Each diam ...
- PTA(Advanced Level)1044.Shopping in Mars
Shopping in Mars is quite a different experience. The Mars people pay by chained diamonds. Each diam ...
- 1044 Shopping in Mars (25 分)
Shopping in Mars is quite a different experience. The Mars people pay by chained diamonds. Each diam ...
随机推荐
- windows cmd中查看某个命令所在的路径
需求描述: 之前用linux环境下的which命令就能看到某个命令的绝对路径, 然后想在windows下的cmd中是否也能够查看到命令的绝对路径呢 操作过程: 1.windows环境下,通过where ...
- C#操作MSMQ示例
C#操作MSMQ示例,示例代码: using System; using System.Collections.Generic; using System.Linq; using System.Tex ...
- JBPM4.4_执行流程实例
1. 执行流程实例 1.1. 启动流程实例 说明:流程实例创建后,直接就到开始活动后的第一个活动,不会在开始活动停留. 1.1.1. 示例代码1:使用指定key的最新版本的流程定义启动流程实例 Pro ...
- m2014-architecture-imgserver->Lighttpd +mod_mem_cache的效果简直太好了
公司的图片服务器一直以来负载都比较高,原因是图片比较分散而且比较小.经常把iowait搞的特别的高.但是只有一台机器也法用squid,经测试squid和apache在同一台机器效果会很糟糕的.因为sq ...
- 新唐ARM9之NUC972学习历程之系统的搭建和BSP包的使用
说到嵌入式,我们首先想到的,就是它的复杂程度,LINUX,BSP,UBOOT,交叉编译,寄存器配置,等等一系列的问题,甚至有的时候我们对此一头雾水,很是头疼,不过我们今天要说的就是关于NUC972的一 ...
- C++中的三种继承public,protected,private
( c++默认class是private继承且class内的成员默认都是private struct 默认位public 继承,struct内成员默认是public ) 三种访问权限 public: ...
- MQTT的学习研究(一)MQTT学习网站
MQTT的官方推荐网站: http://mqtt.org/software 使用IBM 的MQTT协议实现push消息地址: http://tokudu.com/2010/how-to-impleme ...
- The 70th problem,UVa10396 Vampire Numbers
今天看Thinking in Java看到一个吸血鬼数的问题,于是查找UVa里也有类似的问题就动手写了先是用Java写的,不过WA了两次,然后没有发现错误,又用c++写的还是不行.最后发现要排序去重. ...
- python实现HTTP代理的思路和Demo
一.首先什么是代理: 代理其实就是中间转发的那个玩意,所以在代码逻辑上也是如此的. 二.Python写http代理的基本逻辑: (1)接受浏览器发出的请求,解析,拼凑成该有的样子,然后使用套接字发出去 ...
- {sharepoint} Setting List Item Permissions Programatically in sharepoint
namespace Avinash { class Program { static void Main(string[] args) { SetListItemPermission(); } sta ...