用LUA(和C++)刷PAT (Advanced Level) ——1076 Forwards on Weibo

这篇博客探讨了使用C++和Lua两种编程语言实现关注关系的层次计算。通过输入用户关注信息,程序能计算任意用户在多级关注链上的关注人数。文章以一个满分的C++实现和一个导致超时的Lua实现为例,突显了不同语言在处理复杂度相同的问题时,性能表现的差异。
摘要由CSDN通过智能技术生成

3000毫秒也会超时啊…
满分的C++:

#include <iostream>

using namespace std;

int main()
{
    bool info[1001][6][1001];
    int N, L, K;
    cin>>N>>L;
    for(int person_index = 1; person_index <= N; person_index++ )
        for(int level = 0; level < L; level++ )
            info[person_index][level][person_index] = true;
    
    for (int person_t = 1; person_t <= N; person_t++ ){
        int NN;
        cin>>NN;
        for(int i = 0; i < NN; i++ ){
            int person_index;
            cin>>person_index;
            info[person_index][0][person_t] = true;
        }
    }
    for (int level = 1; level < L; level++)
        for (int person_index = 1; person_index <= N; person_index++)//对每个人
            for (int person_t = 1; person_t <= N; person_t++)//计算其它所有人
                if(info[person_index][0][person_t])//如果是他直接关注的
                    for (int person_tt = 1; person_tt <= N; person_tt++)//去看看
                        if(info[person_t][level-1][person_tt])//如果直接关注的人level-1层间接关注了
                            info[person_index][level][person_tt] = true;//那么level层间接关注

    cin>>K;
    for(int i = 0; i < K; i++){
        int person_index;
        cin>>person_index;
        int count = 0;
        for(int person_t = 1; person_t <= N; person_t++)
            if(info[person_index][L-1][person_t])
                count ++;
        cout<<count - 1 <<endl;
    }
}

超时的lua:

local readF = io.read('*a'):gmatch('%d+')
local readFunc = function() return tonumber(readF()) end

local N = readFunc() L = readFunc()
local info = {}

for i = 1, N do
    info[i] = {}
end

for i = 1, N do
    for j = 1, L do
        info[i][j] = {}
        info[i][j][i] = true
    end
end

for i = 1, N do
    local NN = readFunc()
    for j = 1, NN do
        info[readFunc()][1][i] = true
    end
end

for level = 2, L do
    for person_index = 1, N do
        for idol, _ in pairs(info[person_index][1]) do
            for idol_trigger, _ in pairs(info[idol][level - 1]) do
                info[person_index][level][idol_trigger] = true
            end
        end
    end
end

local K = readFunc()

for i = 1, K do
    local person_index = readFunc() count = 0
    for _, _ in pairs(info[person_index][L]) do
        count = count + 1
    end
    print(count - 1)
end
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值