94022024-02-21 12:51:28Leventusz09Táblajáték 2 (70 pont)csharpHibás válasz 28/7032ms26420 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("ALMA");
            Console.WriteLine("{0}\n{1}", r, o2);
        }
    }
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
base28/70
1Elfogadva0/030ms22452 KiB
2Hibás válasz0/030ms23108 KiB
3Elfogadva2/230ms23036 KiB
4Részben helyes1/330ms23352 KiB
5Elfogadva3/332ms23468 KiB
6Részben helyes1/330ms23964 KiB
7Elfogadva3/330ms24416 KiB
8Részben helyes1/330ms24416 KiB
9Részben helyes1/332ms24776 KiB
10Részben helyes1/330ms24932 KiB
11Elfogadva3/330ms25116 KiB
12Részben helyes1/332ms24960 KiB
13Részben helyes1/332ms25396 KiB
14Részben helyes1/330ms25716 KiB
15Részben helyes1/430ms25608 KiB
16Részben helyes1/430ms25568 KiB
17Részben helyes1/429ms26016 KiB
18Részben helyes1/430ms25960 KiB
19Részben helyes1/429ms25916 KiB
20Részben helyes1/432ms25904 KiB
21Részben helyes1/432ms26240 KiB
22Részben helyes1/430ms26348 KiB
23Részben helyes1/330ms26420 KiB