2016届蓝桥杯大赛软件类国赛Java大学B组 反幻方 暴力搜索

简介: 2016届蓝桥杯大赛软件类国赛Java大学B组 反幻方 暴力搜索

题目

答案

 
import java.util.HashSet;
import java.util.Scanner;
 
public class Main {
  static Scanner sc=new Scanner(System.in);
    public static void main(String[] args) {
      int cnt=0;
      for(int i1=1;i1<=9;i1++) {
        for(int i2=1;i2<=9;i2++) {
          for(int i3=1;i3<=9;i3++) {
            for(int i4=1;i4<=9;i4++) {
              for(int i5=1;i5<=9;i5++) {
                for(int i6=1;i6<=9;i6++) {
                  for(int i7=1;i7<=9;i7++) {
                    for(int i8=1;i8<=9;i8++) {
                      for(int i9=1;i9<=9;i9++) {
                        // 先去掉重复的元素
                        HashSet<Integer> hs1=new HashSet<>();
                        hs1.add(i1);
                        hs1.add(i2);
                        hs1.add(i3);
                        hs1.add(i4);
                        hs1.add(i5);
                        hs1.add(i6);
                        hs1.add(i7);
                        hs1.add(i8);
                        hs1.add(i9);
                        if(hs1.size()<9)continue;
                        // 互不相等
                        int ans1=(i1+i2+i3);
                        int ans2=(i4+i5+i6);
                        int ans3=(i7+i8+i9);
                        int ans4=(i2+i5+i8);
                        int ans5=(i3+i6+i9);
                        int ans6=(i1+i4+i7);
                        int ans7=(i1+i5+i9);
                        int ans8=(i3+i5+i7);
                        HashSet<Integer> hs2=new HashSet<>();
                        hs2.add(ans1);
                        hs2.add(ans2);
                        hs2.add(ans3);
                        hs2.add(ans4);
                        hs2.add(ans5);
                        hs2.add(ans6);
                        hs2.add(ans7);
                        hs2.add(ans8);
                        if(hs2.size()<8)continue;
                      cnt++;
                        } 
                      }
                    } 
                  } 
                } 
              } 
            } 
          }
      }
      //旋转或者镜像算是一种
      System.out.print(cnt/4/2);
    }
}

这段代码的功能是找出所有满足以下条件的九个不同的数字组合 (i1, i2, i3, i4, i5, i6, i7, i8, i9)

  1. 每个数字都在 19 的范围内。
  2. 这九个数字互不相同。
  3. 分别计算八个组合的和,确保这八个和值也是互不相同的。

代码分析

  1. 嵌套循环
  • 使用九层嵌套的 for 循环,分别遍历可能的 i1i9 的取值,保证每个数在 19 的范围内,并且每个数都不相同。
  1. 去重
  • 在每组 (i1, i2, ..., i9) 中使用 HashSet 进行去重,确保这九个数字都是唯一的。如果 HashSet 的大小小于 9,则说明有重复数字,直接跳过当前组合。
  1. 计算和
  • 计算八个不同的组合的和,分别是 (i1+i2+i3), (i4+i5+i6), (i7+i8+i9), (i2+i5+i8), (i3+i6+i9), (i1+i4+i7), (i1+i5+i9), (i3+i5+i7)
  1. 去重和计数
  • 同样使用 HashSet 来存储这八个和值,确保它们也是唯一的。如果 HashSet 的大小小于 8,则说明有重复的和值,跳过当前组合。
  • 如果通过了上述条件,增加 cnt 的计数,表示找到了一组满足条件的组合。
  1. 结果输出
  • 最后输出 cnt / 4 / 2,这是因为对于每组符合条件的数字组合,考虑到旋转和镜像是等效的,所以要除以 4(四种旋转或镜像方式),再除以 2(镜像算一种)。

总结

这段代码的目的是通过嵌套循环和条件判断,找出所有满足要求的九个不同数字的组合,并计算出符合条件的组合数目。通过使用 HashSet 来确保数字和组合的唯一性,同时利用数学的和值条件来进一步筛选有效的组合。

个人号推广

博客主页

多多!-CSDN博客

Web后端开发

https://blog.csdn.net/qq_30500575/category_12624592.html?spm=1001.2014.3001.5482

Web前端开发

https://blog.csdn.net/qq_30500575/category_12642989.html?spm=1001.2014.3001.5482

数据库开发

https://blog.csdn.net/qq_30500575/category_12651993.html?spm=1001.2014.3001.5482

项目实战

https://blog.csdn.net/qq_30500575/category_12699801.html?spm=1001.2014.3001.5482

算法与数据结构

https://blog.csdn.net/qq_30500575/category_12630954.html?spm=1001.2014.3001.5482

计算机基础

https://blog.csdn.net/qq_30500575/category_12701605.html?spm=1001.2014.3001.5482

回忆录

https://blog.csdn.net/qq_30500575/category_12620276.html?spm=1001.2014.3001.5482

目录
相关文章
|
7天前
|
存储 安全 Java
java.util的Collections类
Collections 类位于 java.util 包下,提供了许多有用的对象和方法,来简化java中集合的创建、处理和多线程管理。掌握此类将非常有助于提升开发效率和维护代码的简洁性,同时对于程序的稳定性和安全性有大有帮助。
35 17
|
3天前
|
存储 Java 程序员
Java基础的灵魂——Object类方法详解(社招面试不踩坑)
本文介绍了Java中`Object`类的几个重要方法,包括`toString`、`equals`、`hashCode`、`finalize`、`clone`、`getClass`、`notify`和`wait`。这些方法是面试中的常考点,掌握它们有助于理解Java对象的行为和实现多线程编程。作者通过具体示例和应用场景,详细解析了每个方法的作用和重写技巧,帮助读者更好地应对面试和技术开发。
27 4
|
4天前
|
Java 编译器 开发者
Java异常处理的最佳实践,涵盖理解异常类体系、选择合适的异常类型、提供详细异常信息、合理使用try-catch和finally语句、使用try-with-resources、记录异常信息等方面
本文探讨了Java异常处理的最佳实践,涵盖理解异常类体系、选择合适的异常类型、提供详细异常信息、合理使用try-catch和finally语句、使用try-with-resources、记录异常信息等方面,帮助开发者提高代码质量和程序的健壮性。
11 2
|
8天前
|
存储 安全 Java
如何保证 Java 类文件的安全性?
Java类文件的安全性可以通过多种方式保障,如使用数字签名验证类文件的完整性和来源,利用安全管理器和安全策略限制类文件的权限,以及通过加密技术保护类文件在传输过程中的安全。
|
12天前
|
Java 数据格式 索引
使用 Java 字节码工具检查类文件完整性的原理是什么
Java字节码工具通过解析和分析类文件的字节码,检查其结构和内容是否符合Java虚拟机规范,确保类文件的完整性和合法性,防止恶意代码或损坏的类文件影响程序运行。
|
12天前
|
Java API Maven
如何使用 Java 字节码工具检查类文件的完整性
本文介绍如何利用Java字节码工具来检测类文件的完整性和有效性,确保类文件未被篡改或损坏,适用于开发和维护阶段的代码质量控制。
|
12天前
|
存储 Java 编译器
java wrapper是什么类
【10月更文挑战第16天】
20 3
|
15天前
|
Java 程序员 测试技术
Java|让 JUnit4 测试类自动注入 logger 和被测 Service
本文介绍如何通过自定义 IDEA 的 JUnit4 Test Class 模板,实现生成测试类时自动注入 logger 和被测 Service。
20 5
|
15天前
|
Java
在Java多线程编程中,实现Runnable接口通常优于继承Thread类
【10月更文挑战第20天】在Java多线程编程中,实现Runnable接口通常优于继承Thread类。原因包括:1) Java只支持单继承,实现接口不受此限制;2) Runnable接口便于代码复用和线程池管理;3) 分离任务与线程,提高灵活性。因此,实现Runnable接口是更佳选择。
27 2
|
15天前
|
Java
Java中多线程编程的基本概念和创建线程的两种主要方式:继承Thread类和实现Runnable接口
【10月更文挑战第20天】《JAVA多线程深度解析:线程的创建之路》介绍了Java中多线程编程的基本概念和创建线程的两种主要方式:继承Thread类和实现Runnable接口。文章详细讲解了每种方式的实现方法、优缺点及适用场景,帮助读者更好地理解和掌握多线程编程技术,为复杂任务的高效处理奠定基础。
27 2