zoukankan      html  css  js  c++  java
  • Java

    题目:

    现在有一个容器,里面有n个物品,编号为1-n,现在小q可以进行一些操作,每次取出任意两个数,可以把这两个数的编号相加,相减,相乘,再把结果放回容器。问最后小q能否在n-1次操作后使得容器里的唯一一个物品的编号为24?

    输入:

    一个n (1 ≤ n ≤ 105).

    输出:

    如果小q不能,就输出一个"NO",否者输出一个"YES",并给出小q操作的方案。(若有多种操作方案,给出其中一种即可)

    样例:

    1
    NO
     
    4
    YES
    2 * 4 = 8
    3 * 8 = 24
    1 * 24 = 24
     
    8
    YES
    8 * 7 = 56
    6 * 5 = 30
    3 - 4 = -1
    1 - 2 = -1
    30 - -1 = 31
    56 - 31 = 25
    25 + -1 = 24

    代码:

    import java.util.Arrays;
    import java.util.Scanner;
    public class A24game {
        public static void main(String[] args) {
            Scanner scanner = new Scanner(System.in);
            int n = scanner.nextInt();
            if (n<=3) {
                System.out.println("NO");
            }else {
                System.out.println("YES");
                if(n%2==0){
                    if(n>=4){
                        if (n==4) {
                            System.out.println("2 * 4 = 8");
                            System.out.println("3 * 8 = 24");
                            System.out.println("1 * 24 = 24");
                        }
                        while(n!=4){
                            System.out.println(n+" - "+(n-1)+" = "+1);
                            if(n==6){
                                System.out.println("2 * 4 = 8");
                                System.out.println("3 * 8 = 24");
                                System.out.println("1 * 24 = 24");
                                System.out.println(1+" * "+24+" = "+24);
                            }else {
                                System.out.println(1+" * "+1+" = "+1);
                            }
                            
                            n = n-2;
                        }
    
    
                    }
                }else {
                    if(n>=5){
                        if (n==5) {
                            System.out.println("1 + 5 = 6");
                            System.out.println("3 - 2 = 1");
                            System.out.println("1 * 4 = 4");
                            System.out.println("4 * 6 = 24");
                        }
                        while(n!=5){
                            System.out.println(n+" - "+(n-1)+" = "+1);
                            if(n==7){
                                System.out.println("1 + 5 = 6");
                                System.out.println("3 - 2 = 1");
                                System.out.println("1 * 4 = 4");
                                System.out.println("4 * 6 = 24");
                                System.out.println(1+" * "+24+" = "+24);
                            }else {
                                System.out.println(1+" * "+1+" = "+1);
                            }
                            n = n-2;
                        }
    
                    }
                }
            }
        }
    }
  • 相关阅读:
    [EF]vs15+ef6+mysql code first方式
    Asp.net MVC]Asp.net MVC5系列——布局视图
    Asp.net MVC]Asp.net MVC5系列——Routing特性
    Asp.net MVC]Asp.net MVC5系列——Razor语法
    Asp.net MVC]Asp.net MVC5系列——实现编辑、删除与明细信息视图
    Asp.net MVC]Asp.net MVC5系列——在模型中添加验证规则
    Asp.net MVC]Asp.net MVC5系列——在模型中添加
    Django跨域(前端跨域)
    Stark组件
    Admin组件
  • 原文地址:https://www.cnblogs.com/xiaoyh/p/15226881.html
Copyright © 2011-2022 走看看