拉丁矩阵 回溯 c java

2024-06-21 04:58
文章标签 java 矩阵 回溯 拉丁

本文主要是介绍拉丁矩阵 回溯 c java,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

现有n种不同形状的宝石,每种宝石有足够多颗。欲将这些宝石排列成m行n列的一个矩阵,m n,使矩阵中每一行和每一列的宝石都没有相同形状。试设计一个算法,计算出对于给定的m和n有多少种不同的宝石排列方案。
方法一:(从左往右,从上往下,依次填写,保证上方,左方没有重复的)
import java.util.Scanner;public class LaDingJuZhen3 {static int[][] x;static int m;    //行static int n;    //列static int mn;static int count=0;public static void main(String[] args) {Scanner input = new Scanner(System.in);m=input.nextInt();n=input.nextInt();mn=(m)*(n);input.close();x=new int[m][n];Backtrack(0);System.out.println(count);}public static void Backtrack(int t){int i=t/n;int j=t%n;if(t>=mn){count ++;return;}for (int k = 0; k < n ; k++) {if(isOk(i, j, k)){x[i][j]=k;Backtrack(t+1);}}}public static boolean isOk(int i,int j,int k){for (int l = 0; l < i; l++) {if(x[l][j]==k){return false;}}for (int l = 0; l < j; l++) {if(x[i][l]==k){return false;}}return true;}
}


方法2:每一行n个不同的数,行作为深度,求每一行的全排列,保证行列不重复




import java.util.Scanner;public class LaDingJuZhen2 {static int[][] x;static int m;static int n;static int count=0;public static void main(String[] args) {Scanner input = new Scanner(System.in);m=input.nextInt();n=input.nextInt();input.close();x=new int[m+1][n+1];for (int i = 0; i < m+1; i++) {for (int j = 0; j < n+1; j++) {x[i][j]=j;}}Backtrack(1, 1);System.out.println(count);}public static void outPut(){for (int i = 1; i <= m; i++) {for (int j = 1; j <= n; j++) {System.out.print(x[i][j]+"  ");}System.out.println();}System.out.println();}public static boolean ok(int s,int t){for (int i = 1; i < s; i++) {for (int j = 1; j <= n; j++) {if(x[i][j]==x[s][j]) {return false;}}}return true;}public static void  swap(int x1,int y1,int x2,int y2){int t;t=x[x1][y1];x[x1][y1]=x[x2][y2];x[x2][y2]=t;}public static void Backtrack(int s,int t){   //s表示行  t表示列if(s>m){count++;outPut();return;}if(t>n){if(ok(s, t)){Backtrack(s+1, 1);}}for (int i = t; i <= n; i++) {swap(s, i, s, t);Backtrack(s, t+1);swap(s, i, s, t);}}
}



 
#include"iostream"
using namespace std;
int **x;
int count=0;
int s;
int t;
int m;
int n;
int no=0;
void OutPut()
{for(int i=1;i<=m;i++){for(int j=1;j<=n;j++)cout<<x[i][j]<<ends;cout<<endl;}
// cout<<endl;
}
void swap(int &a,int &b)//要用引用
{int p;p=a;a=b;b=p;
}
int OK(int**x,int s,int t)
{for(int k=1;k<s;k++)for(int j=1;j<=n;j++)if(x[k][j]==x[s][j]) return 0;return 1;
}
void Backtrack(int s,int t)
{int j;if(s>m){count++;// no++;// cout<<"矩阵:"<<no<<endl;// OutPut();return;}if(t>n){  if(OK(x,s,t))Backtrack(s+1,1);}for(j=t;j<=n;j++){swap(x[s][j],x[s][t]);Backtrack(s,t+1);swap(x[s][j],x[s][t]);}
}
void main()
{int i,j;cin>>n>>m;x=new int*[m+1];for(i=0;i<=m;i++)x[i]=new int[n+1];for(i=0;i<=m;i++)for(j=0;j<=n;j++)x[i][j]=j;Backtrack(1,1);cout<<count<<endl;
}


这篇关于拉丁矩阵 回溯 c java的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1080272

相关文章

Java编译生成多个.class文件的原理和作用

《Java编译生成多个.class文件的原理和作用》作为一名经验丰富的开发者,在Java项目中执行编译后,可能会发现一个.java源文件有时会产生多个.class文件,从技术实现层面详细剖析这一现象... 目录一、内部类机制与.class文件生成成员内部类(常规内部类)局部内部类(方法内部类)匿名内部类二、

SpringBoot实现数据库读写分离的3种方法小结

《SpringBoot实现数据库读写分离的3种方法小结》为了提高系统的读写性能和可用性,读写分离是一种经典的数据库架构模式,在SpringBoot应用中,有多种方式可以实现数据库读写分离,本文将介绍三... 目录一、数据库读写分离概述二、方案一:基于AbstractRoutingDataSource实现动态

Springboot @Autowired和@Resource的区别解析

《Springboot@Autowired和@Resource的区别解析》@Resource是JDK提供的注解,只是Spring在实现上提供了这个注解的功能支持,本文给大家介绍Springboot@... 目录【一】定义【1】@Autowired【2】@Resource【二】区别【1】包含的属性不同【2】@

springboot循环依赖问题案例代码及解决办法

《springboot循环依赖问题案例代码及解决办法》在SpringBoot中,如果两个或多个Bean之间存在循环依赖(即BeanA依赖BeanB,而BeanB又依赖BeanA),会导致Spring的... 目录1. 什么是循环依赖?2. 循环依赖的场景案例3. 解决循环依赖的常见方法方法 1:使用 @La

Java枚举类实现Key-Value映射的多种实现方式

《Java枚举类实现Key-Value映射的多种实现方式》在Java开发中,枚举(Enum)是一种特殊的类,本文将详细介绍Java枚举类实现key-value映射的多种方式,有需要的小伙伴可以根据需要... 目录前言一、基础实现方式1.1 为枚举添加属性和构造方法二、http://www.cppcns.co

Elasticsearch 在 Java 中的使用教程

《Elasticsearch在Java中的使用教程》Elasticsearch是一个分布式搜索和分析引擎,基于ApacheLucene构建,能够实现实时数据的存储、搜索、和分析,它广泛应用于全文... 目录1. Elasticsearch 简介2. 环境准备2.1 安装 Elasticsearch2.2 J

Java中的String.valueOf()和toString()方法区别小结

《Java中的String.valueOf()和toString()方法区别小结》字符串操作是开发者日常编程任务中不可或缺的一部分,转换为字符串是一种常见需求,其中最常见的就是String.value... 目录String.valueOf()方法方法定义方法实现使用示例使用场景toString()方法方法

Java中List的contains()方法的使用小结

《Java中List的contains()方法的使用小结》List的contains()方法用于检查列表中是否包含指定的元素,借助equals()方法进行判断,下面就来介绍Java中List的c... 目录详细展开1. 方法签名2. 工作原理3. 使用示例4. 注意事项总结结论:List 的 contain

Java实现文件图片的预览和下载功能

《Java实现文件图片的预览和下载功能》这篇文章主要为大家详细介绍了如何使用Java实现文件图片的预览和下载功能,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... Java实现文件(图片)的预览和下载 @ApiOperation("访问文件") @GetMapping("

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis