• POJ 3320 Jessica‘s Reading Problem 尺取法


    一、题目大意

    给定一个长度为p的数组,其中可能包含重复元素,找到包含数组所有元素至少一次的连续最短序列长度

    二、解题思路

    我们可以使用尺取法定义左(left)右(right)两个指针,代表[left,right)为当前有效长度(左闭右开),按照如下思路进行尺取法

    1. 1、不断的移动right,直到right=p或者[left,right)中包含数组全部元素至少一次
    2. 2、如果right=p,但是[left,right)仍然不包含全部元素至少一次,退出程序
    3. 3、记录 result = min (result , res)
    4. 4、放大left

    在获取输入的时候,可以使用set去重,然后set的大小len就是去重后的数量,可以使用map记录每个元素出现的个数,当right右移时,判断如果有元素右移之前是0变成1了,把sum+1,同时不管sun是否变化,都要更新map里的值,然后不断增大right,直到sum==len

    当left右移动时,从map中拿到去掉的元素出现的次数,如果去掉之后这个元素出现了0次,那么sum-1,同时不管sum是否变化,一定要更新map

    然后每次sum==len时,更新结果为min(result,right-left)

    三、代码

    1. #include
    2. #include
    3. #include
    4. using namespace std;
    5. int arr[1000007], n = 0, len = 0, distinctArr[1000007], countArr[1000007], res;
    6. map<int, int> cntMap;
    7. void input()
    8. {
    9. scanf("%d", &n);
    10. res = n;
    11. set<int> distinctSet;
    12. for (int i = 0; i < n; i++)
    13. {
    14. scanf("%d", &arr[i]);
    15. distinctSet.insert(arr[i]);
    16. cntMap[arr[i]] = 0;
    17. }
    18. len = distinctSet.size();
    19. }
    20. void solve()
    21. {
    22. // 我们设置[left,right)为有效范围
    23. int left = 0, right = 0, sum = 0, cnt;
    24. while (left <= right)
    25. {
    26. while (right < n && sum < len)
    27. {
    28. cnt = cntMap[arr[right]];
    29. if (cnt == 0)
    30. {
    31. sum++;
    32. }
    33. cnt++;
    34. cntMap[arr[right++]] = cnt;
    35. }
    36. if (sum < len)
    37. {
    38. return;
    39. }
    40. res = min(res, right - left);
    41. cnt = cntMap[arr[left]];
    42. cnt--;
    43. if (cnt == 0)
    44. {
    45. sum--;
    46. }
    47. cntMap[arr[left++]] = cnt;
    48. }
    49. }
    50. int main()
    51. {
    52. input();
    53. solve();
    54. printf("%d\n", res);
    55. return 0;
    56. }

  • 相关阅读:
    音视频技术开发周刊 | 251
    全面总结 pip install 与 conda install 的使用区别
    TrendMicro:Apex One Server 工具文件夹
    go io.Copy 实现 端口转发 SSH 代理
    Spring
    Hadoop的由来、Block切分、进程详解
    computer planetary MoBI:生物多样性重要性地图
    【MYSQL】索引
    内网Windows Git Server部署
    程序员月薪8000,丢人吗?
  • 原文地址:https://blog.csdn.net/qq_53038151/article/details/132723582