mysql排列组合实现_Java实现数列的排列组合

定义:

排列:从给定个数的元素中取出指定个数的元素,进行排序

组合:从给定个数的元素中仅取出指定个数的元素,不考虑排序

公式:

从n个元素中取出m个元素进行排序的个数:

A(m,n)=n*(n-1)(n-2)...*(n-m+1)=n!/(n-m)!

从n个元素中取出m个元素进行组合的个数:

C(m,n)=n!/[m!*(n-m)!]

注意:

0!=1

代码实现:

计算阶乘,排列数,组合数

/**

* 计算n的阶乘:n! = n * (n-1) * (n-2) * ... *2 * 1

*/

public static long factorial(int n){

return (n>1) ? n*factorial(n-1) : 1;

}

/**

* 计算排列数:A(n, m) = n!/(n-m)! -- 从n个数中取出m个数进行排列 ,需要考虑数的顺序 (如果n个数进行排列,有n!种情况)

*/

public static long arrangement(int n, int m){

return (n >= m) ? factorial(n)/factorial(n-m) : 0;

}

/**

* 计算组合数:C(n, m) = n!/((n-m)! * m!) -- 从n个数中取出m个数进行排列 ,不考虑数的顺序 (如 1234 和 4321 属于一种组合,都包含1,2,3,4这四个数)

*/

public static long combination(int m, int n){

return (n >= m) ? factorial(n)/(factorial(n-m)*factorial(m)) : 0;

}

穷举出所有的排列结果

/**

* 排列:从数组a中选择n个数进行排列

*/

public static void arrangementSelect(int[] a, int n){

System.out.println(String.format("A(%d, %d) = %d", a.length, n, arrangement(a.length, n)));

arrangementSort(a, new int[n], 0);

}

/**

* 通过递归的方式罗列出所有的排列结果

* @param a:初始数组

* @param result:排列数组初始状态

* @param resultIndex:比较的起始索引

*/

public static void arrangementSort(int[] a, int[] result, int resultIndex){

int result_length = result.length;

if(resultIndex >= result_length){

System.out.println(Arrays.toString(result)); // 输出排列结果

return;

}

for(int i=0; i

// 判断待选的数是否存在于排列的结果中

boolean exist = false;

for(int j=0; j

if(a[i] == result[j]){ // 若已存在,则不能重复选

exist = true;

break;

}

}

if(!exist){ // 若不存在,则可以选择

result[resultIndex] = a[i];

arrangementSort(a, result, resultIndex+1);

}

}

}

穷举出所有的组合结果

/**

* 组合:从数组a中选择n个数进行组合

*/

public static void combinationSelect(int a[], int n){

System.out.println(String.format("C(%d, %d)= %d", a.length, n, combination(a.length, n)));

combinationSort(a, 0, new int[a.length], 0);

}

/**

* 通过递归的方式罗列出所有的组合结果

* @param a:初始数组

* @param a_index:初始数组起始下标

* @param result:初始组合数组

* @param r_index:初始组合数组的起始下标

*/

public static void combinationSort(int[] a, int a_index, int[] result, int r_index){

int r_len = result.length;

int r_count = r_index + 1;

if(r_count > r_len){

System.out.println(Arrays.toString(result)); // 输出组合结果

return;

}

for(int i=a_index; i

result[r_index] = a[i];

combinationSort(a, i+1, result, r_index+1);

}

}

完整代码

import java.util.Arrays;

public class Main {

public static void main(String[] args) {

int[] a = {1, 2, 3, 4}; // 初始数组

arrangementSelect(a, 4);

combinationSelect(a, 3);

}

/**

* 计算n的阶乘:n! = n * (n-1) * (n-2) * ... *2 * 1

*/

public static long factorial(int n){

return (n>1) ? n*factorial(n-1) : 1;

}

/**

* 计算排列数:A(n, m) = n!/(n-m)! -- 从n个数中取出m个数进行排列 ,需要考虑数的顺序 (如果n个数进行排列,有n!种情况)

*/

public static long arrangement(int n, int m){

return (n >= m) ? factorial(n)/factorial(n-m) : 0;

}

/**

* 计算组合数:C(n, m) = n!/((n-m)! * m!) -- 从n个数中取出m个数进行排列 ,不考虑数的顺序 (如 1234 和 4321 属于一种组合,都包含1,2,3,4这四个数)

*/

public static long combination(int m, int n){

return (n >= m) ? factorial(n)/(factorial(n-m)*factorial(m)) : 0;

}

/**

* 排列:从数组a中选择n个数进行排列

*/

public static void arrangementSelect(int[] a, int n){

System.out.println(String.format("A(%d, %d) = %d", a.length, n, arrangement(a.length, n)));

arrangementSort(a, new int[n], 0);

}

/**

* 通过递归的方式罗列出所有的排列结果

* @param a:初始数组

* @param result:排列数组初始状态

* @param resultIndex:比较的起始索引

*/

public static void arrangementSort(int[] a, int[] result, int resultIndex){

int result_length = result.length;

if(resultIndex >= result_length){

System.out.println(Arrays.toString(result)); // 输出排列结果

return;

}

//

for(int i=0; i

// 判断待选的数是否存在于排列的结果中

boolean exist = false;

for(int j=0; j

if(a[i] == result[j]){ // 若已存在,则不能重复选

exist = true;

break;

}

}

if(!exist){ // 若不存在,则可以选择

result[resultIndex] = a[i];

arrangementSort(a, result, resultIndex+1);

}

}

}

/**

* 组合:从数组a中选择n个数进行组合

*/

public static void combinationSelect(int a[], int n){

System.out.println(String.format("C(%d, %d)= %d", a.length, n, combination(a.length, n)));

combinationSort(a, 0, new int[a.length], 0);

}

/**

* 通过递归的方式罗列出所有的组合结果

* @param a:初始数组

* @param a_index:初始数组起始下标

* @param result:初始组合数组

* @param r_index:初始组合数组的起始下标

*/

public static void combinationSort(int[] a, int a_index, int[] result, int r_index){

int r_len = result.length;

int r_count = r_index + 1;

if(r_count > r_len){

System.out.println(Arrays.toString(result)); // 输出组合结果

return;

}

for(int i=a_index; i

result[r_index] = a[i];

combinationSort(a, i+1, result, r_index+1);

}

}

}

运行结果:

A(4, 4) = 24

[1, 2, 3, 4]

[1, 2, 4, 3]

[1, 3, 2, 4]

[1, 3, 4, 2]

[1, 4, 2, 3]

[1, 4, 3, 2]

[2, 1, 3, 4]

[2, 1, 4, 3]

[2, 3, 1, 4]

[2, 3, 4, 1]

[2, 4, 1, 3]

[2, 4, 3, 1]

[3, 1, 2, 4]

[3, 1, 4, 2]

[3, 2, 1, 4]

[3, 2, 4, 1]

[3, 4, 1, 2]

[3, 4, 2, 1]

[4, 1, 2, 3]

[4, 1, 3, 2]

[4, 2, 1, 3]

[4, 2, 3, 1]

[4, 3, 1, 2]

[4, 3, 2, 1]

C(4, 3)= 0

[1, 2, 3, 4]

Process finished with exit code 0

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 要导出 MySQL 数据库中的数据,可以使用以下步骤: 1. 首先,您需要使用 JDBC 驱动程序连接到您的 MySQL 数据库。如果您还没有安装 JDBC 驱动程序,请下载并安装 MySQL Connector/J。 2. 接下来,您需要编写一个 Java 程序来连接到 MySQL 数据库并执行 SELECT 查询以检索数据。 3. 将检索到的数据写入 CSV 文件或 Excel 文件中。 以下是一个使用 JavaMySQL Connector/J 导出数据的示例程序: ```java import java.io.FileWriter; import java.io.IOException; import java.sql.*; public class ExportData { public static void main(String[] args) throws Exception { // 数据库连接参数 String url = "jdbc:mysql://localhost:3306/mydb"; String user = "root"; String password = "mypassword"; // 创建数据库连接 Connection conn = DriverManager.getConnection(url, user, password); // 创建查询语句 String sql = "SELECT * FROM users"; // 执行查询 Statement stmt = conn.createStatement(); ResultSet rs = stmt.executeQuery(sql); // 创建 CSV 文件 FileWriter writer = new FileWriter("users.csv"); // 写入表头 ResultSetMetaData metaData = rs.getMetaData(); int columnCount = metaData.getColumnCount(); for (int i = 1; i <= columnCount; i++) { writer.append(metaData.getColumnName(i)); if (i < columnCount) { writer.append(","); } } writer.append("\n"); // 写入数据 while (rs.next()) { for (int i = 1; i <= columnCount; i++) { String value = rs.getString(i); writer.append(value); if (i < columnCount) { writer.append(","); } } writer.append("\n"); } // 关闭资源 writer.close(); rs.close(); stmt.close(); conn.close(); System.out.println("Data exported successfully."); } } ``` 此程序将从名为 `users` 的表中检索数据并将其写入名为 `users.csv` 的 CSV 文件中。您可以根据需要修改查询和文件名。 ### 回答2: Java导出MySQL是一种常见的操作,可以使用Java编程语言来实现。 首先,需要使用Java中的JDBC(Java Database Connectivity)来连接MySQL数据库。通过加载MySQL的JDBC驱动程序并建立与数据库的连接,我们可以使用Java代码来执行SQL查询和操作。 在导出MySQL数据库之前,需要确定要导出的表格和数据。可以使用MySQL提供的工具(如MySQL Workbench)来查看数据库结构和数据内容。 接下来,可以使用Java编写代码来导出MySQL数据库。可以通过以下步骤来实现: 1. 在Java代码中,使用JDBC来连接到MySQL数据库。 2. 使用SQL语句查询数据库中所有表格的信息,可以使用如下SQL语句: ```sql SHOW TABLES; ``` 3. 遍历每个表格,使用SQL语句查询表格结构信息和数据,可以使用如下SQL语句: ```sql SELECT * FROM 表格名称; ``` 4. 将查询结果保存到文件中,可以使用Java的文件操作类(如FileWriter、BufferedWriter等)来将数据写入到文件中。 5. 循环处理每个表格,重复步骤3和步骤4,直到导出所有表格的结构和数据。 6. 关闭数据库连接和文件流,确保资源的释放。 需要注意的是,在导出MySQL数据库之前,请确保已正确配置MySQL的JDBC驱动,并在Java项目中添加所需的依赖。 总结起来,通过Java编程语言结合JDBC,可以连接到MySQL数据库并查询表格结构和数据,然后将结果保存到文件中,以实现MySQL数据库的导出功能。 ### 回答3: Java导出MySQL是通过使用Java提供的JDBC(Java数据库连接)库实现的。以下是一个基本的示例代码,用于导出MySQL数据库中的数据: 1. 首先,确保已经安装了Java Development Kit(JDK)以及MySQL数据库。 2. 在项目中添加MySQL连接器的JAR文件,例如mysql-connector-java.jar。 3. 创建一个Java类,并导入所需的包,如java.sql和java.io。 4. 在Java类中,创建一个数据库连接对象并指定连接参数,如主机名、端口、用户名、密码和数据库名称。 ```java import java.sql.Connection; import java.sql.DriverManager; import java.sql.ResultSet; import java.sql.Statement; import java.io.FileWriter; import java.io.IOException; public class MySQLExport { public static void main(String[] args) { String url = "jdbc:mysql://localhost:3306/database_name"; // 替换为实际的数据库连接参数 String user = "username"; // 替换为实际的用户名 String password = "password"; // 替换为实际的密码 try { // 创建数据库连接 Connection conn = DriverManager.getConnection(url, user, password); // 创建Statement对象 Statement stmt = conn.createStatement(); // 执行SQL查询语句 String query = "SELECT * FROM table_name"; // 替换为实际的表名 ResultSet rs = stmt.executeQuery(query); // 创建输出文件 FileWriter fileWriter = new FileWriter("exported_data.csv"); // 替换为实际的输出文件路径 // 将结果写入文件 while (rs.next()) { // 根据导出的需求,将数据写入文件 String data = rs.getString("column_name") + ","; // 替换为实际的列名 // 继续添加其他列的数据 fileWriter.write(data); } // 关闭资源 rs.close(); stmt.close(); conn.close(); fileWriter.close(); System.out.println("数据成功导出至exported_data.csv文件。"); } catch (Exception e) { e.printStackTrace(); } } } ``` 以上代码将连接到指定的MySQL数据库,执行查询语句并将结果导出到一个名为exported_data.csv的CSV文件中。如果有其他的导出需求,可以根据具体的需求调整代码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值