4454. 未初始化警告

摘要
Title: 4454. 未初始化警告
Tag: 哈希表
Memory Limit: 64 MB
Time Limit: 1000 ms

Powered by:NEFU AB-IN

Link

4454. 未初始化警告

  • 题意

    第25次CCF计算机软件能力认证 A

    一个未经初始化的变量,里面存储的值可能是任意的。
    因此直接使用未初始化的变量,比如将其赋值给另一个变量,并不符合一般的编程逻辑。
    代码中出现这种情况,往往是因为遗漏了初始化语句、或是打错了变量名。
    对代码中使用了未初始化变量的语句进行检查,可以方便地排查出代码中的一些隐秘 Bug。
    考虑一段包含 k 条赋值语句的简单代码。
    该段代码最多使用到 n 个变量,分别记作 a1,a2,⋯,an;该段代码使用的常量均记作 a0。
    第 i 条(1≤i≤k)赋值语句为 axi=ayi,满足 1≤xi≤n、0≤yi≤n,表示将 ayi 的值赋给变量 axi。
    其中 axi 被称为该赋值语句的左值,一定是个变量;ayi 被称为右值,可以是一个常量或变量。
    对于任意一条赋值语句 axi=ayi,如果右值 ayi 是一个变量,则其应该在此之前被初始化过。
    具体来说,如果变量 ayi 在前 i−1 条赋值语句中做为左值出现过,即存在 j<i 满足 xj=yi(这里无需考虑第 j 条赋值语句本身是否也有右值未初始化的问题),我们就认为在第 i 条赋值语句中 ayi 已被初始化;否则,我们认为该条语句存在右值未初始化的问题。
    按照上述规则,试统计给定的代码中,有多少条赋值语句右值未被初始化。

  • 思路

    动态标记已经被赋值过的值即可

  • 代码

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    /*
    * @Author: NEFU AB-IN
    * @Date: 2023-01-10 19:18:03
    * @FilePath: \Acwing\4454\4454.cpp
    * @LastEditTime: 2023-01-10 19:40:12
    */
    #include <bits/stdc++.h>
    using namespace std;
    #define int long long
    #undef int

    #define SZ(X) ((int)(X).size())
    #define ALL(X) (X).begin(), (X).end()
    #define IOS \
    ios::sync_with_stdio(false); \
    cin.tie(nullptr); \
    cout.tie(nullptr)
    #define DEBUG(X) cout << #X << ": " << X << '\n'
    typedef pair<int, int> PII;

    const int N = 1e5 + 10, INF = 0x3f3f3f3f;

    signed main()
    {
    IOS;
    int n, k, cnt = 0;
    cin >> n >> k;
    unordered_map<int, int> mp;
    for (int i = 1; i <= k; ++i)
    {
    int l, r;
    cin >> l >> r;
    if (!mp.count(r) && r)
    cnt++;
    mp[l] = 1;
    }
    cout << cnt;
    return 0;
    }
使用搜索:谷歌必应百度