社区讨论

TLE 2个点,还能优化吗(不改算法)?

P2661[NOIP 2015 提高组] 信息传递参与者 3已保存回复 3

讨论操作

快速查看讨论及其快照的属性,并进行相关操作。

当前回复
3 条
当前快照
1 份
快照标识符
@m41btlyp
此快照首次捕获于
2024/11/28 21:04
去年
此快照最后确认于
2025/11/04 13:43
4 个月前
查看原帖
CPP
#include<bits/stdc++.h>
using namespace std;
int n;
int f[200005],a[200005];
int main(){
	cin>>n;
	for(int i=1;i<=n;i++) {
		cin>>a[i];
		f[i]=a[i];
	}
	int flag=1;
	int num=0;
	while(flag==1){
		num++;
		for(int i=1;i<=n;i++){
			f[i]=a[f[i]];
			if(f[i]==i){
				flag=0;
				cout<<num;
				return 0;
			} 
		}
	}
}

回复

3 条回复,欢迎继续交流。

正在加载回复...