Register__ 2022-02-04 19:50 采纳率: 89.5%
浏览 27
已结题

C/C++ 一个算法题,我用各种方法都超时了

各种方法了 各种容器我都用上了
但是依旧提交 一直超时

img


之前有人 用哈希表 ,我现在对那个还不是很熟 , 知道,但不知用什么思路

  • 写回答

1条回答 默认 最新

  • _GX_ 2022-02-04 20:30
    关注
    #include <iostream>
    #include <limits>
    #include <unordered_map>
    
    int main()
    {
        int n;
        std::cin >> n;
        int min_a = 0;
        int min_dist = std::numeric_limits<int>::max();
        std::unordered_map<int, int> map;
        for (int i = 0; i < n; i++)
        {
            int a;
            std::cin >> a;
            auto itr = map.find(a);
            if (itr != map.end())
            {
                int d = i - itr->second;
                if (d < min_dist)
                {
                    min_dist = d;
                    min_a = a;
                }
            }
            map[a] = i;
        }
        if (min_dist == std::numeric_limits<int>::max())
            std::cout << "No";
        else
            std::cout << min_a;
        return 0;
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 2月6日
  • 已采纳回答 2月4日
  • 修改了问题 2月4日
  • 创建了问题 2月4日

悬赏问题

  • ¥15 微信会员卡等级和折扣规则
  • ¥15 微信公众平台自制会员卡可以通过收款码收款码收款进行自动积分吗
  • ¥15 随身WiFi网络灯亮但是没有网络,如何解决?
  • ¥15 gdf格式的脑电数据如何处理matlab
  • ¥20 重新写的代码替换了之后运行hbuliderx就这样了
  • ¥100 监控抖音用户作品更新可以微信公众号提醒
  • ¥15 UE5 如何可以不渲染HDRIBackdrop背景
  • ¥70 2048小游戏毕设项目
  • ¥20 mysql架构,按照姓名分表
  • ¥15 MATLAB实现区间[a,b]上的Gauss-Legendre积分