topic:

For any positive integer *n* , if it is an even number, cut it in half; if it is an odd number, then cut (3 *n* +1) in half.

When we verify the Karaz conjecture, in order to avoid double counting, we can record every number encountered during the recursion. For example, when verifying *n* = 3, we need to calculate 3, 5, 8, 4, 2, 1, and then when we verify *n* = 5, 8, 4, 2, we can directly determine the Karaz conjecture. It is not necessary to repeat the calculation because these 4 numbers have been encountered when verifying 3. We call 5, 8, 4, and 2 the numbers "covered" by 3. We call a number *n* in a sequence a "key number" if *n* cannot be covered by other numbers in the sequence.

Given a series of numbers to be verified, we only need to verify a few key ones, so we don't have to repeat the verification of the remaining numbers. Your task is to find these key numbers and output them in order from big to small.

Idea:

At first, there was no clear idea.I made a draft on the paper and found that the key point is how to determine the coverage and how to handle it after determining the coverage? Then use a very stupid method

1.Set up an array to store the numbers that need to be calculated when verifying each number, and then compare them one by one with the known number series

2.After the comparison, the covered number in the original sequence is set to zero.The idea extended from this point is to add if in the first layer of the loop to determine whether it is zero. If it is zero, you can skip the comparison directly, which will also save Unnecessary steps

The recursive process function is relatively simple.Incoming n (the number of a given sequence), comparing the array (copy []), the return value is int, that is, the number of numbers in the recursive process.

callatz( int n, int copy[]){ int callatz ( int n, int copy []) { i = 0 ; int i = 0 ; { do { (n% 2 == 0 ) n = n/ 2 ; if (n% 2 == 0 ) n = n / 2 ; n = (n* 3 + 1 )/ 2 ; else n = (n * 3 + 1 ) / 2 ; ++] = n; copy [i ++] = n; while (n!= 1 ); } while (n! = 1 ); = i- 1 ; i = i- 1 ; i; return i; }

The main function requires that the results be output in order from large to small.First, they must be found out and put into an array.

__
__

n; int n; void )scanf( " %d " ,& n); ( void ) scanf ( " % d " , & n); str[n]; // 存放已知数列 int str [n]; // stores a known sequence copy[SIZE]; // 存放递推过程里的数 int copy [SIZE]; // Store the number during recursion ( int i = 0 ;i < n;i++ ){ for ( int i = 0 ; i <n; i ++ ) { void )scanf( " %d " ,& str[i]); ( void ) scanf ( " % d " , & str [i]); } ( int y = 0 ;y < n;y++ ){ for ( int y = 0 ; y <n; y ++ ) { (str[y]!= 0 ){ // 判定是否为零,为零说明该数已被覆盖 if (str [y]! = 0 ) { // determine if it is zero, if it is zero, the number has been overwritten size = callatz(str[y], copy); // 递推过程中数的个数 // 开始和已知数列比较,同时更新已知数列 int size = callatz (str [y], copy); // The number of numbers in the recursive process // Start comparison with the known sequence and update the known sequence at the same time ( int i = 0 ;i < size;i++ ){ for ( int i = 0 ; i <size; i ++ ) { ( int z = 0 ;z < n;z++ ){ for ( int z = 0 ; z <n; z ++ ) { (str[z]== copy[i]) if (str [z] == copy [i]) = 0 ; str [z] = 0 ; } } } }

Then define a new array to store the results, sort them and output

** **

z = 0 ; int z = 0 ; new [n]; int new [n]; ( int i = 0 ;i < n;i++ ){ for ( int i = 0 ; i <n; i ++ ) { (str[i]!= 0 ) if (str [i]! = 0 ) [z++] = str[i]; new [z ++] = str [i]; } 排序最简单的选择排序.... // Sort the easiest choice to sort ... min = 0 ,temp; int min = 0 , temp; ( int i = 0 ;i < z- 1 ;i++ ){ for ( int i = 0 ; i <z- 1 ; i ++ ) { = i; temp = i; ( int j = i+ 1 ;j <z;j++ ){ for ( int j = i + 1 ; j <z; j ++ ) { ( new [j] > new [temp]){ if ( new [j]> new [temp]) { = j; temp = j; } } = new [i]; min = new [i]; [i] = new [temp]; new [i] = new [temp]; [temp] = min; new [temp] = min; } i = 0 ; int i = 0 ; (i = 0 ;i < z- 1 ;i++ ){ for (i = 0 ; i <z- 1 ; i ++ ) { " %d " , new [i]); printf ( " % d " , new [i]); } " %d " , new [z- 1 ]); printf ( " % d " , new [z- 1 ]); " \n " ); // 输出格式的要求 printf ( " \ n " ); // Requirements for output format

The report was wrong because it was sorted wrong, so we need to study the sorting again … The basic skills are too shameful