题目链接

题意

两个人玩扑克,共n张牌,第一个人k1张,第二个人k2张

给定输入的牌的顺序就是出牌的顺序

每次分别比较两个人牌的第一张,牌上面数字大的赢,把这两张牌给赢的人,并且大的牌放在这个人的牌最下面,另外一张放在上面牌的上面,其他牌在放在这两张牌的上面。

求要pk多少次结束游戏,并记录赢得是哪个人

若出现死循环的情况输出 –1

 

这里可以根据栈或队列

java的程序是根据栈的,比较时候取出栈顶,加入新的两个 数的时候,要先出栈,在入栈,有点麻烦

Python程序是根据队列,在头取出进行比较,加入时候再队尾加入元素,不会出现过度的入栈和出栈的操作

Java 的有增加了队列实现

ArrayList可实现队列的功能,比较简单了

Java程序

复制代码
import java.awt.List;
import java.io.PrintStream;
import java.util.ArrayList;
import java.util.Scanner;
import java.util.Stack;


public class C546 {
    static void run1(){
        Scanner in =new Scanner(System.in);
        PrintStream out = System.out;
        int n = in.nextInt();
        int Maxtime =1000;
        ArrayList<Integer> l1 = new ArrayList<Integer>();
        ArrayList<Integer> l2 = new ArrayList<Integer>();
        int k1 = in.nextInt();
        for(int i=1;i<=k1;i++) l1.add(in.nextInt());
        int k2 = in.nextInt();
        for(int i=1;i<=k2;i++) l2.add(in.nextInt());
        int count =0;
        while(l1.size()>0 && l2.size()>0 &&Maxtime>0){
            count++;
            Maxtime--;
            int q1 = l1.get(0);
            int q2 = l2.get(0);
            l1.remove(0);
            l2.remove(0);
            if(q1> q2){
                l1.add(q2);
                l1.add(q1);
            }else{
                l2.add(q1);
                l2.add(q2);
            }
        }
        if(Maxtime==0)
            out.println(-1);
        else
            out.println(count+" "+(l1.size()>0?1:2));
    }
    static void run(){
        Scanner in = new Scanner(System.in);
        PrintStream out = System.out;
        int n = in.nextInt();
        int k1 = in.nextInt();
        Stack s1 = new Stack();
        Stack s2 = new Stack();
        int[] a1 = new int[k1];
        for(int i=0;i<k1;i++)
            a1[i] = in.nextInt();
        int k2 = in.nextInt();
        int[] a2 = new int[k2];
        for(int i=0;i<k2;i++){
                a2[i] = in.nextInt();
            }
        for(int i=k1-1;i>=0;i--)
            s1.push(a1[i]);
        for(int i=k2-1;i>=0;i--)
            {s2.push(a2[i]);
            }
        int Maxtime = 10000;
        int count = 0;
        boolean flag = false;
        while(! s1.isEmpty()  && ! s2.isEmpty() && Maxtime>0){
            int p1 = (Integer) s1.pop();
            int p2 = (Integer) s2.pop();
            if(p1<p2){
                int[] a3 = new int[s2.size()+2];
                
                for(int i=0;i<a3.length-2;i++)
                    a3[i] = (Integer) s2.pop();
                a3[a3.length-2] = p1;
                a3[a3.length-1] = p2;// max 
                for(int i= a3.length-1;i>=0;i--)
                    { 
                    s2.add(a3[i]);
                    }
                count++;
            }else{
                int[] a4 = new int[s1.size()+2];
                
                for(int i=0;i<a4.length-2;i++)
                    a4[i] = (Integer) s1.pop();
                a4[a4.length-2] = p2;
                a4[a4.length-1] = p1; // max 
                for(int i= a4.length-1;i>=0;i--)
                    s1.add(a4[i]);
                count++;
            }
            Maxtime--;
            
        }
        if(Maxtime==0)
            System.out.println(-1);
        else if(s1.isEmpty())
            System.out.println(count+" "+2);
        else
            out.println(count+" "+ 1);
    }
    public static void main(String[] args){
//        run();
        
        run1();
    }
}
复制代码

Python 程序

def C546():
     n = int(raw_input())
     l=lambda:map(int,raw_input().split())
     a = l()[1:]
     b = l()[1:]
     c = 0
     R = set()
     while a and b:
         c +=1
         A = a.pop(0)
         B = b.pop(0)
         if A > B:
             a+=[B,A]
         else:
             b+=[A,B]
         r =(tuple(a),tuple(b))
         if r in R :
             print -1
             exit(0)
         R.add(r)
     print c, 1 if a else 2
    
if __name__=='__main__':
    #A546()
    #B546()
    C546()