Skip to content
This repository has been archived by the owner on Dec 2, 2021. It is now read-only.

Latest commit

 

History

History
39 lines (31 loc) · 938 Bytes

题解-面试真题.md

File metadata and controls

39 lines (31 loc) · 938 Bytes

题解-面试真题

  • 记录一些暂时没找到原型的面试真题

Index

给定 n[0,n)区间内的数,统计每个数出现的次数,不使用额外空间

头条

思路

  • 基于两个基本运算:
    若 i ∈ [0, n),则有
      (t*n + i) % n = i
      (t*n + i) / n = t 
  • 顺序遍历每个数 i,i 每出现一次,则 nums[i] += n
  • 遍历结束后,i 出现的次数,即 nums[i] / n,同时利用 nums[i] % n 可以还原之前 nums[i] 上的数。

C++(未测试)

vector<int> nums;

void init(vector<int>& nums) {
    for (int i = 0; i < nums.size(); i++) {
        nums[nums[i]] += n;
    }
}

int cnt(int k) {
    return nums[k] / n;
}