分糖果

  • N个小孩站成一排,每个小孩必须给一块糖,标记等级高的小孩给的糖应该比其邻居高,且每个小孩至少要有一块,球所需的给的最少的糖的数目:
 int candy(vector<int> &ratings)
 {
     int size=ratings.size();
     if(size<=1)
         return size;
     vector<int> num(size,1);
     for (int i = 1; i < size; i++)
     {
         if(ratings[i]>ratings[i-1])
             num[i]=num[i-1]+1;
     }
     for (int i= size-1; i>0 ; i--)
     {
         if(ratings[i-1]>ratings[i])
             num[i-1]=max(num[i]+1,num[i-1]);
     }
     int result=0;
     for (int i = 0; i < size; i++)
     {
         result+=num[i];
        // cout<
     }
     return result;
 }

你可能感兴趣的:(算法)