LeetCode之小孩分糖果

给定一群站好队的小孩而且按某项分值排名(姑且如果为年龄吧),年龄大的要比他身边年龄小的拿的糖要多。求怎么分配糖果使得分配的糖果数最少。

用一个数组从左到右再从右到左的遍历,向前遍历时若右边的比左边的大则其值为前一个糖果数+1,向后遍历时则推断假设比后面的小孩的年龄要大且糖果数比其还少则更改其糖果数为后面小孩分的糖果数+1.

详细描写叙述代码:

#include<iostream>
#include<vector>

using namespace std;

int candy(vector<int> &a){
     int len=a.size();
   if(len==0||len==1)
   return len;
   
   int sum=0;
   int *candys = new int[len];
   candys[0]=1;
   for(int i=1;i<len;i++)
   {
     if(a[i]>a[i-1])
      candys[i]=candys[i-1]+1;
     else 
      candys[i]=1;
   }
   sum=candys[len-1];
   for(int i=len-2;i>=0;i--)
   {
      if( a[i]>a[i+1] && ( candys[i+1]+1 > candys[i] ))
      candys[i]=candys[i+1]+1;
      sum+=candys[i];
   }
   return sum;
}

int main()
{
  int Array[]={4,2,3,4,1};
  vector<int> c(Array,Array+5);  
  cout<<candy(c)<<endl;

}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值