2157.cpp

来自「杭电 acm部分代码 有兴趣的可以下载 谢谢」· C++ 代码 · 共 54 行

CPP
54
字号
#include <iostream>
using namespace std;
int hash[30][30];
int dest[30][30][30];
int main()
{
    long m, n, t;
    long a, b, i, j, k, o;
    while (scanf("%ld %ld", &n, &m) == 2)
    {
        if (m == 0 && n == 0)
        {
            break;
        }
        memset(hash, 0, sizeof(hash));
        memset(dest, 0, sizeof(dest));

        for (i = 0; i < m; i++)
        {
            scanf("%ld %ld", &a, &b);
            hash[a][b] = 1;
        }

		memcpy(dest[0], hash, sizeof(hash));

        for (i = 1; i < 21; i++)
        {
            for (j = 0; j < n; j++)
            {
                for (k = 0; k < n; k++)
                {
                    for (o = 0; o < n; o++)
                    {
                        dest[i][j][k] += (dest[i - 1][j][o] * hash[o][k]) % 1000; 
                    }
                }
            }
        }
        scanf("%ld", &t);
        for (i = 0; i < t; i++)
        {
			scanf("%ld %ld %ld", &a, &b, &o);
			if (a == b && o == 0)
			{
				printf("1\n");
			}
			else
			{
				printf("%ld\n", dest[o - 1][a][b] % 1000);
			}
        }
    }
    return 0;
}

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?