百练 2705 跳绳游戏

总时间限制:
1000ms
内存限制:
65536kB
描述
小朋友玩跳绳比赛,要计算在一分钟内跳了多少下.假设每秒钟跳一下,如果中途失败了,则要花三秒钟后才能开始重跳.一般小朋友跳绳一分钟要跳坏好几次.现在给出小朋友每次跳坏时已经跳的总数,求小朋友在一分钟内跳了多少下.( 请注意分析示例数据.)
输入
第一行为n个小朋友
其余各行,每行第一个整数是跳坏的次数m,其余m个整数是跳坏时累计跳了多少下.
输出
输出相应小朋友头一分钟内跳了多少下.
样例输入
6
0
3 12 23 45 
1 17
4 10 20 30 40
5 10 20 30 40 58 
6 10 20 30 40 47 60
样例输出
60
51
57
48
48
47
提示
提示,在跳绳比赛时,你可能已经超时了,但自己还在计数,但裁判已经停止计时并得到成绩了.这里相当与自己计数.因此,并非跳坏的时候都是在前一分钟以内.请注意分析示例数据.
 
有数学方法可知只需找出数据在60范围内的最大的数,然后判断 
①考虑57-59秒失败的特殊情况
②对于超出60秒的多余数据的处理
如果不在这范围内,就满足60-3*i的统一规律。
 
代码:
  #include "stdio.h"
#include "malloc.h"
int main()
{  int i,j,n;
  scanf("%d",&j);
  while(j--)
 { scanf("%d",&n);
  int *a=(int *)malloc(sizeof(int)*n);
   for(i=0;i<n;i++)
    {scanf("%d",&a[i]);}
    printf("%d\n",60-3*n);
  }
    return 0;
   
  }  错误代码,因为没考虑在57-60的特殊数据
 
正确代码:
#include "stdio.h"
#include "malloc.h"
int main ()
{  int i ,j ,n ,k = 0 ;
  int m = 0 ;
  int r = 0 ,f = 0 ;
  scanf ( "%d" ,&j );
  while (j --)
{ scanf ( "%d" ,&n );
  int *a =( int *) malloc ( sizeof ( int )*n );     //申请动态数组
   for (i = 0 ;i <n ;i ++)
    { scanf ( "%d" ,&a [i ]);
   
      }

      f = 0 ;
      for (i = 0 ;i <n ;i ++)                               //寻找后面数据中的最大值,找到后跳出
     {  if (f !=- 1 &&((a [i ])+ 3 *(i +1 ))> 59 )
         {
            f = 1 ;      
            break ;
        
    
         }
      }
      //m=60-3*(1+k);
      if (f &&a [i ]<= 60 &&((a [i ])+ 3 *i )<= 60 )         //①考虑57-59秒失败的特殊情况
      printf ( "%d \n " ,a [i ]);
      else
     //printf("%d\n",a[k+1]);
    printf ( "%d \n " , 60-3 *i );        
  free(a);
  }
    return 0 ;
   
  }

转载于:https://www.cnblogs.com/songmingtao/p/3224835.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值