9404 2024. 02. 21 12:54:25 Leventusz09 Táblajáték 2 (70 pont) csharp Hibás válasz 28/70 32ms 25844 KiB
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Threading.Tasks;

namespace Táblajáték_2{
    class Program{
        static void Main(){
            int K = int.Parse(Console.ReadLine());
            int[] S = Console.ReadLine().Split().Select(int.Parse).ToArray();

            //K = 80;
            //S = "1 0 2 1 0 2 1 0 2 4 3 2 3 2 5 5 0 2 0 3 0 2 4 5 4 0 5 5 5 2 4 4 2 3 4 4 0 4 3 3 0 3 5 4 3 0 2 2 1 1 4 4 2 1 3 0 0 1 3 0 3 1 3 2 5 5 4 2 2 3 2 5 4 0 0 5 4 3 4 1".Split().Select(int.Parse).ToArray();


            /*string o1 = "00";

            for(int i=0, l; i<K; i++){
                l = o1.Length;
                if (S[i] == 0) o1 += "0";
                else if (S[i] == 1) o1 += "1";
                else if (S[i] == 2) o1 += "2";
                else if (S[i] == 3) o1 = o1.Substring(0, l - 1);
                else if (S[i] == 4) 
                    
                    if (o1[l - 1] == '0') 
                        o1 = o1.Substring(0, l - 2) + (int.Parse(o1[l - 2] + "") - 1) + "2"; 
                    else 
                        o1 = o1.Substring(0, l - 1) + (int.Parse(o1[l - 1] + "") - 1);
                else 
                    if (o1[l - 1] == '2')
                        o1 = o1.Substring(0, l - 2) + (int.Parse(o1[l - 2] + "") + 1) + "0"; 
                    else 
                        o1 = o1.Substring(0, l - 1) + (int.Parse(o1[l - 1] + "") + 1);
            }
            int o2 = int.Parse(o1);*/

            int r = 0, c = 0;

            foreach(int i in S){
                if (i == 0){
                    r++;
                    c *= 3;
                }else if (i == 1){
                    r++;
                    c = c * 3 + 1;
                }else if (i == 2){
                    r++;
                    c = c * 3 + 2;
                }else if (i == 3){
                    r--;
                    c /= 3;
                }else if (i == 4){
                    c--;
                }else c++;
            }

            string o1 = "";
            for(; c > 0;){
                o1 += (c % 3);
                c /= 3;
            }
            string o2 = "";
            for (int i = o1.Length - 1; i >= 0; i--) o2 += o1[i];
            Console.WriteLine("{0}\n{1}", r, o2);
        }
    }
}
Részfeladat Összpont Teszt Verdikt Idő Memória
base 28/70
1 Elfogadva 0/0 30ms 22064 KiB
2 Hibás válasz 0/0 30ms 22612 KiB
3 Elfogadva 2/2 32ms 22792 KiB
4 Részben helyes 1/3 32ms 23252 KiB
5 Elfogadva 3/3 30ms 23352 KiB
6 Részben helyes 1/3 32ms 23712 KiB
7 Elfogadva 3/3 32ms 23900 KiB
8 Részben helyes 1/3 30ms 23728 KiB
9 Részben helyes 1/3 32ms 24184 KiB
10 Részben helyes 1/3 32ms 24556 KiB
11 Elfogadva 3/3 32ms 24872 KiB
12 Részben helyes 1/3 32ms 24296 KiB
13 Részben helyes 1/3 32ms 24516 KiB
14 Részben helyes 1/3 32ms 24800 KiB
15 Részben helyes 1/4 30ms 25012 KiB
16 Részben helyes 1/4 32ms 25292 KiB
17 Részben helyes 1/4 32ms 25112 KiB
18 Részben helyes 1/4 30ms 25476 KiB
19 Részben helyes 1/4 30ms 25660 KiB
20 Részben helyes 1/4 32ms 25576 KiB
21 Részben helyes 1/4 32ms 25572 KiB
22 Részben helyes 1/4 32ms 25404 KiB
23 Részben helyes 1/3 32ms 25844 KiB