用递归与分治策略求解网球循环赛日程表_算法设计:分治法(比赛日程安排)...

一、算法思路

1、思路

分治算法的思想是:对于一个规模位N的问题,若该问题可以容易解决(比如规模N较小),则直接解决,否则将其分解为M个规模较小的子问题,这些子问题互相独立,并且与原问题形式相同,递归的解决这些子问题,然后将各子问题的解合并得到原问题的解

2、分治法适用范围

一般具有以下特征的问题可以使用分治算法求解:

(1)求解问题可以分解为若干个规模较小的相同问题

(2)求解问题的规模分解到一定程度,就能够很容易地求解

(3)合并子问题的解可以得到问题的解

(4)由求解问题所分解的各个子问题是互相独立的

3、分治法的步骤

(1)分解:将要求解的问题划分为规模较小的同类问题

(2)求解:当子问题划分的足够小的时候,用比较简单的方法求解,得到子问题的解

(3)合并:按求解问题的要求,将子问题的解逐层合并,即可构成最终的解

二、分治法实例:比赛日程的安排

1、问题描述

某学校举行乒乓球比赛,在初赛阶段设置为循环赛,设有n位选手参赛,初赛共进行n-1天,每位选手要与其他每一位选手进行一场比赛,然后按积分排名选拔进入决赛的选手。根据学校作息时间,要求每位选手每天必须比赛一场,不能轮空。按此要求为比赛安排具体日程,即决定每天各选手对阵的对手

2、分析

设有n=2^k个选手参加循环赛,那么需要要求设计一个满足以下要求比赛日程表:

1)每个选手必须与其它n-1个选手各赛一次;

2)每个选手一天只能赛一次

3、图解

(1)2个选手的情况

f164f31480fff98497e50b4adfce3b2d.png

如果只有两个选手,那么第0列看作选手编号(我们从0开始对列编号,我们的第0列可以看作每个选手第0天在和自己打),第1列就是在第一天,每个选手要比赛的选手号

(2)如果选手的个数为2^2=4,那么日程安排如下图

582e3b8d49e94f2d498178e62e97c62a.png

如果有4个选手,分别设计4/2=2个选手的比赛日程表,1-2选手前一天的比赛日程表如上图表格左上角的深蓝色子表格部分,3-4选手前一天的比赛日程表如上图表格左下角的子表格。据此,后两天的日程表可以将左上角的子表按其对应位置抄到右下角的子表,左下角的子表可以按其对应位置抄到右上角的子表。(同时,我们注意到,这是表的行列均为参赛选手数2^2 = 4,在用分治法求行、列均为(2^2)/2的长度的子表时,首先确定左上角的子表,左下角的子表可以由左上角的子表加(2^2)/2得到)

(3)如果选手的个数为2^3=8,那么日程安排表如下:

72d0044303414252c41ac7e103592dce.png

选手人数为8时,左上角的子表是选手1至选手4的前三天的比赛日程,左下角是选手5至选手8前三天的比赛日程。据此后四天的比赛日程,就是分别将左上角子表按其对应位置抄到右下角,将左下角的子表按其对应位置抄到右上角。这样就完成了比赛日程的安排

这种解法是把求解2^k个选手的比赛日程问题划分为2^1,2^2,......,2^k个选手的比赛日程问题。也就是说,要求2^k个选手的比赛日程,就要分为两部分,分别求出2^(k-1)个选手的比赛日程,然后再进行合并。当然,这种解法只能求选手个数是2的次幂的情况

在每次迭代求解的过程中,可以看作4部分:

1)求左上角子表:左上角子表是前2^(k-1)个选手的比赛前半程的比赛日程。

2)求左下角子表:左下角子表是剩余的2^(k-1)个选手的比赛前半程比赛日程。这个子表和左上角子表的对应关系是,对应元素等于左上角子表对应元素加2^(k-1)。

3)求右上角子表:等于左下角子表的对应元素

4)求右下角子表:等于左上角子表的对应元素

代码实现如下:

#include

#include

int main(void)

{

int a[9][9];

int x,y,i,j,t;

for(x=0;x<9;x++){

for(y=0;y<9;y++){

a[x][y]=0;

}

}

int n=2;

a[1][1]=1;

a[1][2]=2;

a[2][1]=2;

a[2][2]=1;

for(t=1;t<3;t++){

/*使用分治法填充日程表*/

int temp=n;

n=n*2;

/*扩展左下角*/

for(i=temp+1;i<=n;i++)

for(j=1;j<=temp;j++)

a[i][j]=a[i-temp][j]+temp;

/*扩展右上角*/

for(i=1;i<=temp;i++)

for(j=temp+1;j<=n;j++)

a[i][j]=a[i][j-temp]+temp;

/*扩展右下角*/

for(i=temp+1;i<=n;i++){

for(j=temp+1;j<=n;j++)

a[i][j]=a[i-temp][j-temp];

}

}

//打印结果

for(i=0;i<9;i++){

for(j=0;j<9;j++){

printf("%d ",a[i][j]);

}

printf("");

}

return 0;

}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/567306.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python请编写程序、生成随机密码_利用Python如何生成随机密码

本位实例为大家分享了Python生成随机密码的实现过程&#xff0c;供大家参考&#xff0c;具体内容如下写了个程序&#xff0c;主要是用来检测MySQL数据库的空密码和弱密码的&#xff0c;在这里&#xff0c;定义了三类弱密码&#xff1a;1. 连续数字&#xff0c;譬如123456&#…

centos6.5装mysql好难_centos 6.5装mysql5.7

该楼层疑似违规已被系统折叠 隐藏此楼查看此楼报错er-5.7.17-1.el7.i686 需要--> 处理依赖关系 libc.so.6(GLIBC_2.17)&#xff0c;它被软件包 mysql-community-server-5.7.17-1.el7.i686 需要--> 完成依赖关系计算错误&#xff1a;Package: mysql-community-client-5.7.…

聚类算法 距离矩阵_谱聚类

比起传统的K-means算法&#xff0c;谱聚类对数据分布的适应性更强&#xff0c;计算量也要小很多。1. 谱聚类概述谱聚类是从图论中演化出来&#xff0c;主要思想是吧所有的数据看作空间中的点&#xff0c;这些点之间可以用边连接起来。距离较远的两个点之间的边权重值较低&#…

core mysql 延迟加载_mybatis延迟加载及实例讲解

延迟加载基本概念上面我们已经知道使用association、collection可以实现一对一及一对多映射&#xff0c;association、collection还有另外一个延迟加载的功能。延迟加载(lazy load)是关联对象默认的加载方式&#xff0c;延迟加载机制是为了避免一些无谓的性能开销而提出来的&am…

mysql忘记i密码_Mysql忘记密码处理过程

最近项目用到了Mysql&#xff0c;项目里面没有运维人员&#xff0c;项目经理吩咐我在Linux下搭基础环境&#xff0c;其中遇到各种坑&#xff0c;现在记录一下&#xff0c;方便以后使用。以下内容是从网上摘抄过了的&#xff0c;若有侵权&#xff0c;请联系本人删除。1.mysql5.7…

vlan划分不能上网_VLAN工作原理

什么是VLANVLAN(Virtual LAN)&#xff0c;翻译成中文是“虚拟局域网”。可以看做是在一个物理局域网络上搭建出几个逻辑上分离的几个局域网。举个例子来说&#xff0c;如果一个交换机划分为两个VLAN&#xff0c;则相当于这台交换机逻辑上划分为两个交换机。VLAN的一个简单直观说…

mysql查询条件是小数 查不到6.28_28.mysql数据库之查询

1.查询语句mysql 多表关系 查询语句 索引1.添加数据补充:将一个查询结果插入到另一张表中create table student(name char(10),gender int);insert into student values("jack",1);insert into student values("rose",0);create table student_man(name ch…

控制for each循环次数_CCF CSP编程题解201312-1:出现次数最多的数

试题编号&#xff1a;201312-1试题名称&#xff1a;出现次数最多的数时间限制&#xff1a;1.0s内存限制&#xff1a;256.0MB问题描述:给定n个正整数&#xff0c;找出它们中出现次数最多的数。如果这样的数有多个&#xff0c;请输出其中最小的一个。输入格式:输入的第一行只有一…

python编程优化_掌握六大技巧,让python编程健步如飞!

有人跟我抱怨说python太慢了&#xff0c;然后我就将python健步如飞的六大技巧传授给他&#xff0c;结果让他惊呆了&#xff0c;你也想知道这个秘诀吗?这就告诉你&#xff1a;Python是一门优秀的语言&#xff0c;它能让你在短时间内通过极少量代码就能完成许多操作。不仅如此&a…

python离线安装依赖包_python离线安装外部依赖包的实现

{"moduleinfo":{"card_count":[{"count_phone":1,"count":1}],"search_count":[{"count_phone":4,"count":4}]},"card":[{"des":"阿里技术人对外发布原创技术内容的最大平台&…

python段子_Python爬取内涵段子里的段子

环境&#xff1a;Python3.6#!/usr/bin/env python3#-*-coding:utf-8-*-#version:3.6.4__author__ 杜文涛import requestsimport jsondef get_json_dic(url):global dict_jsonresponse requests.get(urlurl)json_response response.content.decode() #获取r的文本 就是一个js…

r语言中的或怎么表示什么不同_R经典入门 之 R语言的基本原理与概念 -- 200430

一、基本原理R是一种解释型语言&#xff0c;输入的命令可以直接被执行&#xff0c;不同于C等编译语言需要构成完整的程序才能运行。R的语法非常简单和直观。合法的R函数总是带有圆括号的形式&#xff0c;即使括号内没有内容(如&#xff0c;ls())。所有函数后都接有圆括号以区别…

旋流式沉砂池计算_旋流沉砂池设计方法

旋流沉砂池设计接口条件和主要参数设计旋流沉砂池前要确认的接口条件和信息包括&#xff1a;地质、气候等基本设计条件&#xff1b;可用地尺寸及在总图的位置坐标&#xff1b;地坪标高&#xff0c;上下游水位或范围&#xff0c;冻土层高度&#xff0c;管道覆土小深度要求&#…

parallelstream启动的线程数_高并发与多线程网络学习笔记(三)线程组和线程池

线程组线程组的作用是&#xff1a;可以批量管理线程或线程组对象&#xff0c;有效地对线程或线程组对象进行组织。构造函数ThreadGroup(String name)//默认parent为当前线程组 ThreadGroup(ThreadGroup parent, String name)具体方法//评估当前活跃的线程数,包括当前group和子g…

java 缓冲流_Java缓冲流的使用

package java;import org.junit.Test;import java.io.*;/*** 处理流之一&#xff1a;缓冲流的使用** 1.缓冲流&#xff1a;* BufferedInputStream* BufferedOutputStream* BufferedReader* BufferedWriter** 2.作用&#xff1a;提供流的读取、写入的速度* 提高读写速度的原因&a…

pytorch l2正则化_吴恩达深度学习 编程作业六 正则化(2)

推荐守门员应该将球踢到哪个位置&#xff0c;才能让自己的队员用头击中。1.无正则化模型判别是否有正则化与调用其他计算函数。准确率&#xff1a;0.948/0.915明显过拟合overfiting了。2.L2正则化公式如下&#xff0c;在原有cost函数基础上增加L2项&#xff0c;L2为参数w的均方…

java 代码锁_Java中的Lock锁

Lock锁介绍&#xff1a;在java中可以使用 synchronized 来实现多线程下对象的同步访问&#xff0c;为了获得更加灵活使用场景、高效的性能&#xff0c;java还提供了Lock接口及其实现类ReentrantLock和读写锁 ReentrantReadWriteLock。相比synchronized来实现同步&#xff0c;使…

vs中工具箱代表的意思_“日”除了代表太阳,其实还有这种意思,特别是出现在这些词语中的“日”...

对于“日”来说&#xff0c;大家都并不陌生&#xff0c;对于日的成语更是多得数不胜数&#xff0c;今天小编将日字成语进行了一个总结&#xff0c;需要用到的朋友们可以收藏&#xff01;一&#xff1a;以“日”开头的成语&#xff0c;大多数形容的是时间。日积月累、日久天长、…

java 访问路径_java获取项目访问路径的相关方法

java获取项目访问路径的相关方法刘振兴代码分享2016年02月11日6292暂无评论在jsp和class文件中调用的相对路径不同。在jsp里&#xff0c;根目录是WebRoot 在class文件中&#xff0c;根目录是WebRoot/WEB-INF/classes 当然你也可以用System.getProperty("user.dir")获…

java 保存文件在服务器_java文件保存至服务器

import java.io.ByteArrayOutputStream;import java.io.File;import java.io.FileOutputStream;import java.io.InputStream;import java.net.HttpURLConnection;import java.net.URL;public class ImageRequest{/*** 读取网络图片并保存至服务器硬盘中* param imgUrl* return …