将1~n之间的整数按照不同的方式分组,如:按奇偶数分成2组。用策略模式设计一个系统,使得用户应用程序使用该系统中的某个分组策略,能够对1~n之间的整数进行分组。

本文介绍了如何使用策略模式设计一个系统,该系统可以将1~n之间的整数根据不同的策略进行分组。具体策略包括按奇偶数分组和按3的余数分组。通过定义GroupStrategy接口,实现StrategyOne和StrategyTwo类,并在IntegerGroup上下文类中设置和调用策略,实现了灵活的整数分组功能。在Application.java中进行了测试,展示了分组结果。
摘要由CSDN通过智能技术生成
  1. 实验内容

具体要求如下:

  1. 定义策略。定义名字为GroupStrategy的策略接口,该接口中声明一个分组的抽象方法:void group(int n);
  2. 定义具体策略。通过实现GroupStrategy策略接口,定义StrategyOne和StrategyTwo两个具体策略类。
  1. StrategyOne:将1~n之间的整数按奇偶数分成2组,将分组后的整数打印到屏幕。
  2. StrategyTwo:将1~n之间的整数,用3求余分成3组,被3除尽的数为一组、被3除余1的为一组、被3除余2的为一组,将分组后的整数打印到屏幕。
  1. 定义上下文类。定义名字为IntergerGroup的上下文类,该类有一个stratey(GroupStrategy类型)变量,提供以下方法:
  1. 设置策略的方法:

void setStrategy(GroupStrategy strategy);

  1. 委托strategy变量调用具体分组策略实现的方法对1~n之间的整数进行分组,的方法:

void integerDivide(int n);

  1. 编写包含main方法的应用程序类Application.java测试以上程序。测试结果如下:

 

  1. 源代码

//类1. GroupStrategy.java

package ShiYan5;

 

public interface GroupStrategy {

public void group(int n);

}

 

//类2.StrategyOne.java

package ShiYan5;

 

public class StrategyOne implements GroupStrategy{

//将1~n之间的整数按奇偶数分成2组

public void group(int n) {

int[] odd=new int[n];

int[] even=new int[n];

System.out.println("将1-"+n+"按奇偶数分成两组:");

int a=0,b=0;

for(int 

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值