7-5 超市奖票兑换 (10 分)

本文探讨了一个有趣的数学问题,通过编程解决超市促销活动中的连续奖票兑换问题,分析了时间复杂度并提供了一段Java代码。博主分享了如何利用奖票编号规则,计算在特定条件下能兑换的小礼物数量。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

前言:
看了下阅读量最高的那位时间复杂度到了三次方…那我也把我的贴一下(胡乱分析.jpg)

某家超市有一种促销手段,购买金额超过一定金额就给一张随机编号奖票。编号是一个1到100之间的数字。当收集到连续编号的三张贴花时,就可以换一个小礼物。兑换完礼物后,该奖票就作废。

小明经常去某家超市购物,积攒了不少奖票,你帮他看看,能换多少小礼物。
输入格式:

首先是一个正整数N(1<N<100),表示小明手上的奖票的数量。 然后是N个正整数JP(1<=JP<=100),每个数字表示一张奖票的编号。
输出格式:

输出一个数字,表示小明可以换的小礼物的数量。如果不能换小礼物,就输出0。
输入样例:

在这里给出一组输入。例如:

6
3 2 4 6 6 4
结尾无空行

输出样例:

在这里给出相应的输出。例如:

1
结尾无空行

代码长度限制 16 KB 时间限制 400 ms 内存限制 64 MB

答案

import java.util.Scanner;
public class Main {
    public static void main(String[] args){
        Scanner sc = new Scanner(System.in);
        int jp[] = new int[100];
        int len = sc.nextInt();
        while (len>0){
            jp[sc.nextInt()-1]++;
            len--;
        }
        int count = 0;
        for (int i = 0; i < 98;) {
            if (jp[i]!=0 && jp[i+1]!=0 && jp[i+2]!=0){
                count++;
                jp[i]--;
                jp[i+1]--;
                jp[i+2]--;
            }else i++;
        }
        System.out.println(count);
    }
}

复杂度是98加count,数据较大的时候应该还是要好点,当然pta上的那几个测试点应该都无所谓了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值