CF698B.Fix a Tree

普及/提高-

通过率:0%

AC君温馨提醒

该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。

题目描述

A tree is an undirected connected graph without cycles.

Let's consider a rooted undirected tree with nn vertices, numbered 11 through nn . There are many ways to represent such a tree. One way is to create an array with nn integers p1,p2,...,pnp_{1},p_{2},...,p_{n} , where pip_{i} denotes a parent of vertex ii (here, for convenience a root is considered its own parent).

For this rooted tree the array pp is [2,3,3,2][2,3,3,2] .Given a sequence p1,p2,...,pnp_{1},p_{2},...,p_{n} , one is able to restore a tree:

  1. There must be exactly one index rr that pr=rp_{r}=r . A vertex rr is a root of the tree.
  2. For all other n1n-1 vertices ii , there is an edge between vertex ii and vertex pip_{i} .

A sequence p1,p2,...,pnp_{1},p_{2},...,p_{n} is called valid if the described procedure generates some (any) rooted tree. For example, for n=3n=3 sequences (1,2,2), (2,3,1) and (2,1,3) are not valid.

You are given a sequence a1,a2,...,ana_{1},a_{2},...,a_{n} , not necessarily valid. Your task is to change the minimum number of elements, in order to get a valid sequence. Print the minimum number of changes and an example of a valid sequence after that number of changes. If there are many valid sequences achievable in the minimum number of changes, print any of them.

输入格式

The first line of the input contains an integer nn ( 2<=n<=2000002<=n<=200000 ) — the number of vertices in the tree.

The second line contains nn integers a1,a2,...,ana_{1},a_{2},...,a_{n} ( 1<=ai<=n1<=a_{i}<=n ).

输出格式

In the first line print the minimum number of elements to change, in order to get a valid sequence.

In the second line, print any valid sequence possible to get from (a1,a2,...,an)(a_{1},a_{2},...,a_{n}) in the minimum number of changes. If there are many such sequences, any of them will be accepted.

输入输出样例

  • 输入#1

    4
    2 3 3 4
    

    输出#1

    1
    2 3 4 4 
    
  • 输入#2

    5
    3 2 2 5 3
    

    输出#2

    0
    3 2 2 5 3 
    
  • 输入#3

    8
    2 3 5 4 1 6 6 7
    

    输出#3

    2
    2 3 7 8 1 6 6 7
    

说明/提示

In the first sample, it's enough to change one element. In the provided output, a sequence represents a tree rooted in a vertex 44 (because p4=4p_{4}=4 ), which you can see on the left drawing below. One of other correct solutions would be a sequence 2 3 3 2, representing a tree rooted in vertex 33 (right drawing below). On both drawings, roots are painted red.

In the second sample, the given sequence is already valid.

首页