题解 | 正方形中的最多点数

题干分析:

一个以坐标系原点为中心正方形能够容纳多少个标号不同的坐标点,同时要求这些坐标点不能有标号相同的.

首先我们观察到整个过程在整数集下进行讨论,因此正方形的增长为离散的,且大的正方形包含小正方形,因此可以进行逐个大小的正方形计数,直到计数发现有标号重复的点为止.

算法逻辑:

承接初步的思路,为了让我们能够对正方形大小进行枚举计数,我们需要明白在正方形上的点的特征,这里特征很明显,便是相应点的坐标值的绝对值的最大值便是经过该点的正方形大小.同时为了让我们进行逐大小计数,我们需要进行排序.此后直接按照原想法计数即可.

实现代码:

int maxPointsInsideSquare(vector<vector<int>>& points, string s) {
        const int n = static_cast<int>(points.size());
        for (int i = 0; i < n; ++i) { // 初期处理,第一个值变为正方形大小,第二个值为标号索引
            points[i][0] = max(abs(points[i][0]), abs(points[i][1]));
            points[i][1] = s[i] - 'a';
        }
    
  		// 自定义排序
        ranges::sort(points, [&](const vector<int> &a, const vector<int> &b) -> bool {
            return a[0] < b[0];
        });
    
        int ans = 0;
        int has = 0; // 这里用位存储是否存在该标点,节省空间
        int size = points[0][0];
        auto it = points.begin();
  		// 符合要求才计数(it不指向最后,且标号暂时不存) 
        while (it != points.end() && !(has >> (*it)[1] & 1)) {
            int temp = 0; // 计数当前大小正方形上点的数目
            while (it != points.end() && size == (*it)[0] && !(has >> (*it)[1] & 1)) {
                ++temp;
                has |= 1 << (*it)[1];
                ++it;
            }
		  	// 到达最后,正方形仍旧符合,加入总数同时退出循环
            if (it == points.end()) {
                ans += temp;
                break;
            }
		  	// 出内循环时该大小正方形已计数完毕,记录值并更新大小,不然不符合便不计入总数
            if (size != (*it)[0]) {
                ans += temp;
                size = (*it)[0];
            }
        }
    
        return ans;
    }

复杂度分析:

  • 时间复杂度: 排序O(nlog n), 枚举O(n)(依据it,整个过程只有内循环更改it,且it只从数头部移动到数组尾部),总计O(nlog n).
  • 空间复杂度: 排序O(log n)的运行栈空间, 其余只使用到常数额外空间,总计O(log n).
全部评论

相关推荐

今天 12:55
已编辑
五邑大学 前端工程师
走到这一步,确实有些意外。先简单说说我的情况,我是双非本,大一那年对后端兴趣特别浓,学了快一年半。但不知为什么越往后学兴趣越淡——大概到分布式那块,比如nacos、卡夫卡这些,感觉越来越吃力。再加上看到师兄师姐在后端方向上的碰壁(现在是大go时代),在和师兄师姐商量后我在今年一月左右转前端了或许是因为有java的基础,对项目开发流程有些概念,前端三件套我过得比较快。之后学了Vue,动手做了自己的博客,这大概也是我转前端的一个重要原因吧,一直很想拥有一个属于自己的个人博客,能按自己的想法去设计、实现,并长期迭代完善,这种成就感真的很棒。之前拿过别人的开源项目来更改&nbsp;但是自己修改的就是一坨,那个时候缺少对前端代码的理解&nbsp;就算借助ai做出来的效果也是一坨就这样到了大二暑假,我觉得该找份实习,丰富一下简历了。我自认不是很有创造力的人,平时少有自发的项目灵感,所以更希望通过实习开阔眼界、提升能力。一开始投递和面试的过程挺煎熬的,或许是因为目标多是中小厂,很多hr已读不回,或是直接砍半薪资问我接不接受。面试时也常觉得像在走流程,问的都是八股文,有的面试官还会边看题边问,甚至有一次十分钟就结束了,好在最后钛动给了我机会。实习期间我学到了很多,虽然也常被拷打,还好ld会帮我收拾烂摊子。从钛动离职回校后,我半推半就地背八股、学新技术,无聊时就刷里扣、看看牛客和biss。原本以为双非bg很会被hr速度筛掉所以就尝试性的投了纷享销客和百度,没想到最后两家都oc了,雷姆了家人们,双非鼠鼠居然圆了大厂梦yysy,这一路其实冒了不小的风险。毕竟学了那么久的后端,大学四年时间有限,突然转前端,意味着很多积累的知识可能用不上了。但我很庆幸当时有放下的勇气。无论过去做了什么选择,我都想感谢当时的自己,因为那份勇气,才走到了今天。同时也很感谢这一路师兄师姐的帮忙,师兄帮忙模拟面试,提供资料,师姐教我如何选择岗位,如何处理实习带来的问题马上就要北漂了,对未来是充满了期待也存在着恐惧,南方人头一次去这么远的地方,每天都能看到雪,可以跟实力强劲的同事合作,想想都很兴奋,但是也害怕自己不能胜任这份工作会被压力到爆,但是不管怎么样大家一起互勉吧,呆在舒适区只会停滞不前,压力才能带来成长
牛马人的牛马人生:勇敢追梦
2025年终总结
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务