题目描述
考虑一段包含 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 已被初始化;
否则,我们认为该条语句存在右值未初始化的问题。
按照上述规则,试统计给定的代码中,有多少条赋值语句右值未被初始化。
样例
10 7
1 2
3 3
3 0
3 3
6 2
2 1
8 2
输出
3
C++ 代码
#include <iostream>
using namespace std;
/* run this program using the console pauser or add your own getch, system("pause") or input loop */
const int N=100010;
int a[N],b[N];
bool st[N];
int main(int argc, char** argv) {
int n,k,count=0;
cin>>n>>k;
for(int i=0;i<k;i++)
{
cin>>a[i]>>b[i];
}
for(int i=0;i<k;i++)
{
if(b[i]!=0&&st[b[i]]==false)
{
count++;
}
st[a[i]]=true;
}
cout<<count<<endl;
return 0;
}