public startGame(){ super("魔塔(易安制作)"); init(); Container c = getContentPane(); c.setLayout(null); c.setBackground(Color.BLACK); mypanel = new Mypanel(); mypanel.setBounds(200, 32, 352, 352);//操作区 myState = mypanel.new MyState(); myState.setBounds(30, 32, 128, 352);//属性面板 book = new Book(); book.setBounds(100,32,352,352); fenpan = new FenPan(); fenpan.setBounds(100, 32,352,352); c.add(mypanel); c.add(myState); this.getLayeredPane().add(book,new Integer(Integer.MAX_VALUE)); this.getLayeredPane().add(fenpan,new Integer(Integer.MAX_VALUE)); setSize(590, 450); setVisible(true); setLocationRelativeTo(null); setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); addMouseListener(this); addMouseMotionListener(this); mypanel.requestFocus(); }

时间: 2024-04-04 19:33:14 浏览: 155
这段代码是一个Java Swing的窗口程序,它创建了一个名为“魔塔(易安制作)”的窗口,并添加了一个操作区、属性面板、书本和分盘。其中,操作区是一个自定义的面板,用于显示游戏的主要操作界面;属性面板用于显示角色的属性信息;书本和分盘都是用于显示游戏中的一些信息或菜单选项的面板。在程序的最后,它还添加了一些鼠标事件监听器,并将焦点设置为操作区。
相关问题

分析代码: public MyFrame(){ actionPanel.setLayout(new FlowLayout()); actionPanel.add(buttonRestart,BorderLayout.CENTER); this.getContentPane().setLayout(new BorderLayout()); this.getContentPane().add(helpPanel,BorderLayout.NORTH); this.getContentPane().add(gamePanel,BorderLayout.CENTER); this.getContentPane().add(actionPanel,BorderLayout.SOUTH); this.setSize(700,700); this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE); this.setTitle("对对碰"); this.setVisible(true); buttonRestart.addMouseListener(new MouseAdapter(){ public void mouseClicked(MouseEvent e){ if(flag) return ; flag = true; gamePanel.addKeyListener(gamePanel); gamePanel.addMouseListener(gamePanel); gamePanel.startGame(); buttonRestart.setEnabled(false); HelpPanel.score.setText(0+""); new Thread(new Runnable(){ @Override public void run() { nowTime = 0; while(true){ try { Thread.currentThread().sleep(1000); nowTime++; HelpPanel.setTime(nowTime); if(nowTime==100){ gamePanel.removeMouseListener(gamePanel); gamePanel.removeKeyListener(gamePanel); int score = Integer.parseInt(helpPanel.score.getText()); int record = Integer.parseInt(helpPanel.record.getText()); if(score>record){ JOptionPane.showMessageDialog(null, "游戏结束,你的得分是"+score+",刷新了历史记录"+record); helpPanel.updateBestScore(); }else{ JOptionPane.showMessageDialog(null, "游戏结束,你的得分是"+HelpPanel.score.getText()); } buttonRestart.setEnabled(true); flag = false; break; } } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } }).start();; } }); }

这段代码是一个 Java GUI 应用程序中的构造函数 `MyFrame()`。它创建了一个窗口,窗口中包含了一个游戏面板、一个帮助面板和一个动作面板,还有一个重新开始游戏的按钮。具体的实现步骤如下: 1. `actionPanel.setLayout(new FlowLayout());` 设置动作面板的布局方式为流式布局。 2. `actionPanel.add(buttonRestart,BorderLayout.CENTER);` 将重新开始游戏的按钮添加到动作面板上,位置居中。 3. `this.getContentPane().setLayout(new BorderLayout());` 设置窗口的布局方式为边界布局。 4. `this.getContentPane().add(helpPanel,BorderLayout.NORTH);` 将帮助面板添加到窗口的北部位置。 5. `this.getContentPane().add(gamePanel,BorderLayout.CENTER);` 将游戏面板添加到窗口的中央位置。 6. `this.getContentPane().add(actionPanel,BorderLayout.SOUTH);` 将动作面板添加到窗口的南部位置。 7. `this.setSize(700,700);` 设置窗口的大小为 700x700。 8. `this.setDefaultCloseOperation(JFrame.EXIT_ON_CLOSE);` 设置窗口的默认关闭操作为退出程序。 9. `this.setTitle("对对碰");` 设置窗口的标题为“对对碰”。 10. `this.setVisible(true);` 显示窗口。 11. `buttonRestart.addMouseListener(new MouseAdapter(){...});` 为重新开始游戏的按钮添加鼠标单击事件监听器。 12. 在鼠标单击事件监听器中,如果游戏正在进行中,则直接返回;否则,开始游戏,启动一个新的线程计时,当游戏时间达到 100 秒时,结束游戏,显示得分并更新历史记录。最后,重新启用重新开始游戏的按钮,并将游戏状态标志设置为未开始。

document.addEventListener("DOMContentLoaded", startGame, false); function startGame(){if(BABYLON.Engine.isSupported()){ var canvas = document.getElementById("renderCanvas"); var engine = new BABYLON.Engine(canvas, true); BABYLON.SceneLoader.Load("Espilit/", "Espilit.babylon", engine, function(newScene){ var VJC = new BABYLON.VirtualJoysticksCamera("VJC", newScene.activeCamera.position, newScene); VJC.rotation = newScene.activeCamera.rotation; VJC.checkCollisions = newScene.activeCamera.checkCollisions; VJC.applyGravity = newScene.activeCamera.applyGravity; // 等待纹理和着色器完成 newScene.executeWhenReady(function () { newScene.activeCamera = VJC; // 将相机和画布关联 newScene.activeCamera.attachControl(canvas); // 场景加载完成,循环渲染场景 engine.runRenderLoop(function () { newScene.render(); }), }), }, function(progress){ // 反馈 }), } }每一行解释一下

这段代码是使用BABYLON引擎加载一个3D场景,并在场景中创建一个虚拟摇杆相机(VirtualJoysticksCamera),以便用户可以使用虚拟摇杆控制相机的运动。下面是每一行代码的解释: 1. `document.addEventListener("DOMContentLoaded", startGame, false);`: 当DOM文档加载完毕后,调用startGame函数。 2. `function startGame(){`: 定义名为startGame的函数。 3. `if(BABYLON.Engine.isSupported()){`: 检查BABYLON引擎是否被支持。 4. `var canvas = document.getElementById("renderCanvas");`: 获取ID为“renderCanvas”的canvas元素。 5. `var engine = new BABYLON.Engine(canvas, true);`: 创建BABYLON引擎实例,并将它关联到canvas元素上。 6. `BABYLON.SceneLoader.Load("Espilit/", "Espilit.babylon", engine, function(newScene){`: 加载名为“Espilit.babylon”的场景文件,将其关联到engine实例上,并在加载完成后调用一个回调函数。 7. `var VJC = new BABYLON.VirtualJoysticksCamera("VJC", newScene.activeCamera.position, newScene);`: 创建一个名为“VJC”的虚拟摇杆相机,并设置其位置和所在场景。 8. `VJC.rotation = newScene.activeCamera.rotation;`: 将VJC的旋转设置为与场景中的摄像机相同。 9. `VJC.checkCollisions = newScene.activeCamera.checkCollisions;`: 将VJC的碰撞检测设置为与场景中的摄像机相同。 10. `VJC.applyGravity = newScene.activeCamera.applyGravity;`: 将VJC的重力应用设置为与场景中的摄像机相同。 11. `newScene.executeWhenReady(function () {`: 当场景中的所有纹理和着色器都加载完成后,执行一个回调函数。 12. `newScene.activeCamera = VJC;`: 将场景中的活动摄像机设置为VJC。 13. `newScene.activeCamera.attachControl(canvas);`: 将VJC与canvas元素关联,以便用户可以使用虚拟摇杆控制摄像机。 14. `engine.runRenderLoop(function () {`: 循环渲染场景。 15. `newScene.render();`: 渲染场景。 总的来说,这段代码是使用BABYLON引擎创建一个3D场景,并在其中添加一个虚拟摇杆相机,以便用户可以使用虚拟摇杆控制相机的运动。
阅读全文

相关推荐

public class ProcedureMenu : ProcedureLogic { private bool m_StartGame = false; //开始游戏的标志位 private MenuForm m_MenuForm = null; //菜单界面 /// /// 开始游戏 /// public void StartGame() { m_StartGame = true; } public override void OnEnter(IFsm<IProcedureManager> procedureOwner) { GameEntry.Event.Subscribe(OpenUIFormSuccessEventArgs.EventId, OnOpenUIFormSuccess); //订阅打开UI的回调 m_StartGame = false; //执行打开UI操作 GameEntry.UI.OpenUIForm(UIFormID.MenuForm, this); } public override void OnLeave(IFsm<IProcedureManager> procedureOwner, bool isShutdown) { GameEntry.Event.Unsubscribe(OpenUIFormSuccessEventArgs.EventId, OnOpenUIFormSuccess); if (m_MenuForm != null && m_MenuForm.RuntimeUIForm != null) { m_MenuForm.RuntimeUIForm.Close(isShutdown); m_MenuForm = null; } } public override void OnUpdate(IFsm<IProcedureManager> procedureOwner) { if (m_StartGame) { procedureOwner.SetData(Constant.ProcedureData.NextSceneId, new VarInt(GameEntry.Config.GetInt("Scene.Main"))); procedureOwner.SetData(Constant.ProcedureData.GameMode, new VarInt((int)GameMode.Survival)); RuntimeProcedure.ChangeProcedure<HotProcedureChangeScene>(procedureOwner); } } //打开UI成功的回调 private void OnOpenUIFormSuccess(object sender, GameEventArgs e) { OpenUIFormSuccessEventArgs args = e as OpenUIFormSuccessEventArgs; UserUIData uiData = args.UserData as UserUIData; if (uiData.UserData != this) return; m_MenuForm = uiData.RuntimeUIForm.HotLogicInstance as MenuForm; } public override void OnDestroy(IFsm<IProcedureManager> procedureManager) { } }

修改代码,使startGame方法运行到执行getHinder()后回到for(;success;) public void startGame() { Scanner scanner = new Scanner(System.in); while (true) { System.out.println("请选择游戏模式(1-娱乐模式,2-困难模式,0-退出):"); int mode = scanner.nextInt(); if (mode == 0) { break; } List<ChengYu> chengYuList; if (mode == 1) { chengYuList = commonChengYuList; } else { chengYuList = fullChengYuList; } Collections.shuffle(chengYuList); // 打乱顺序 int score = 0; boolean success = true; //随机抽取一个成语 Random random = new Random(); int index = random.nextInt(chengYuList.size()); ChengYu cy = chengYuList.get(index); String currentIdiom = cy.getChengYu(); for(;success;) { System.out.println(hintCount); for (ChengYu chengYu : commonChengYuList) if(chengYu.getChengYu().startsWith((currentIdiom.substring(currentIdiom.length() - 1)))) break; System.out.println("请回答以下成语的下一个成语:" + currentIdiom + "(难度:" + cy.getDifficultyLevel().getName() + ")"); String answer = scanner.next(); if (!cy.isCorrectAnswer(answer,commonChengYuList)) { System.out.println("回答错误!"); success = false; getHint(currentIdiom); } else { score++; } if (success) { System.out.println("恭喜您回答正确,得分:" + score); for (ChengYu nextChengYu : fullChengYuList) if(nextChengYu.getChengYu().startsWith((answer.substring(answer.length() - 1)))) currentIdiom=nextChengYu.getChengYu(); } } } scanner.close(); } //给予用户最多3次提示的机会 private int maxHintCount=3; // 最大提示次数 private int hintCount=0; // 当前提示次数 public String getHint(String currentIdiom) { if (hintCount >= maxHintCount) { System.out.println("提示次数已全部用完,请重新开始游戏!"); hintCount=0; return null; // 已经用完所有提示次数,返回null } for (ChengYu idiom : fullChengYuList) { if(hintCount<maxHintCount) { String reminder=idiom.getChengYu(); if (reminder.startsWith(currentIdiom.substring(currentIdiom.length() - 1))) { System.out.println("提示:"+reminder); hintCount++; break; } } } return null; }

// 外观模式 class GameFacade { private CommandHandler commandHandler; private List observers; private GameMediator mediator; private PlayerProxy playerProxy; private GameAdapter gameAdapter; public GameFacade() { commandHandler = new IdentityHandler(); commandHandler.setNextHandler(new CommandValidationHandler()); observers = new ArrayList<>(); observers.add(new StaminaObserver()); observers.add(new ExperienceObserver()); mediator = new GameMediator(); Player player = new PlayerImpl(); playerProxy= new PlayerProxy(player); Game game = new GameImpl(); gameAdapter = new GameAdapter(game); } public void handleCommand(Command command) { commandHandler.handleCommand(command); } public void notifyPlayerAction(PlayerAction action) { for (PlayerActionObserver observer : observers) { observer.onPlayerAction(action); } } public void addServer(Server server) { mediator.addServer(server); } public void syncData(Server server) { mediator.syncData(server); } public void login() { playerProxy.login(); } public void logout() { playerProxy.logout(); } public void setLanguage(Language language) { gameAdapter.setLanguage(language); } public void setGraphics(Graphics graphics) { gameAdapter.setGraphics(graphics); } // 新增方法:玩家开始游戏 public void startGame() { playerProxy.startGame(); } // 新增方法:玩家结束游戏 public void endGame() { playerProxy.endGame(); } // 新增方法:保存游戏进度 public void saveGame() { mediator.saveGame(); } // 新增方法:读取游戏进度 public void loadGame() { mediator.loadGame(); } }

最新推荐

recommend-type

一个简单的java游戏.zip

《一个简单的Java游戏.zip》是一个专为学习目的设计的Java小游戏资源包。它包含了完整的源代码和必要的资源文件,适合初学者通过实战练习提升编程技能。该项目展示了如何使用Java的图形用户界面(GUI)库创建游戏窗口,并实现基本的游戏逻辑和交互功能。该游戏项目结构清晰,包括了多个类和文件,每个部分都有详细的注释,帮助理解代码的功能和逻辑。例如,Block类用于定义游戏中的基本元素,如玩家和障碍物;CreateGame类则是游戏的主要控制类,负责初始化游戏窗口、处理用户输入以及更新游戏状态等。此外,该资源包还演示了如何绘制游戏元素、处理事件驱动编程以及多线程的应用,这些都是游戏开发中的重要概念。通过运行和修改这个小游戏,用户可以深入了解Java编程的基础知识,并培养解决实际问题的能力。总之,《一个简单的Java游戏.zip》是一个理想的学习工具,无论是对于初学者还是有一定经验的开发者来说,都可以通过这个项目获得宝贵的实践经验。
recommend-type

基于SSM的智慧中医诊所管理系统(前后端代码)

基于SSM的智慧中医诊所管理系统(前后端代码)
recommend-type

chromedriver-win64-133.0.6835.0

当前版本是133.0.6835.0 ChromeDriver 是 Selenium WebDriver 用于控制 Chrome 的独立可执行文件。此扩展程序由 Chromium 团队在 WebDriver 贡献者的帮助下进行维护。如果您不熟悉 Selenium WebDriver,则应访问 Selenium 网站。 请按以下步骤设置测试,以便与 ChromeDriver 一起运行: 确保 Chromium/Google Chrome 安装在可识别的位置 ChromeDriver 希望你将 Chrome 安装到适用于您的平台的默认位置。你还可以通过设置特殊功能强制 ChromeDriver 使用自定义位置。 在本网站的下载部分,下载适用于您平台的 ChromeDriver 二进制文件 帮助 WebDriver 找到已下载的 ChromeDriver 可执行文件
recommend-type

平尾装配工作平台运输支撑系统设计与应用

资源摘要信息:"该压缩包文件名为‘行业分类-设备装置-用于平尾装配工作平台的运输支撑系统.zip’,虽然没有提供具体的标签信息,但通过文件标题可以推断出其内容涉及的是航空或者相关重工业领域内的设备装置。从标题来看,该文件集中讲述的是有关平尾装配工作平台的运输支撑系统,这是一种专门用于支撑和运输飞机平尾装配的特殊设备。 平尾,即水平尾翼,是飞机尾部的一个关键部件,它对于飞机的稳定性和控制性起到至关重要的作用。平尾的装配工作通常需要在一个特定的平台上进行,这个平台不仅要保证装配过程中平尾的稳定,还需要适应平尾的搬运和运输。因此,设计出一个合适的运输支撑系统对于提高装配效率和保障装配质量至关重要。 从‘用于平尾装配工作平台的运输支撑系统.pdf’这一文件名称可以推断,该PDF文档应该是详细介绍这种支撑系统的构造、工作原理、使用方法以及其在平尾装配工作中的应用。文档可能包括以下内容: 1. 支撑系统的设计理念:介绍支撑系统设计的基本出发点,如便于操作、稳定性高、强度大、适应性强等。可能涉及的工程学原理、材料学选择和整体结构布局等内容。 2. 结构组件介绍:详细介绍支撑系统的各个组成部分,包括支撑框架、稳定装置、传动机构、导向装置、固定装置等。对于每一个部件的功能、材料构成、制造工艺、耐腐蚀性以及与其他部件的连接方式等都会有详细的描述。 3. 工作原理和操作流程:解释运输支撑系统是如何在装配过程中起到支撑作用的,包括如何调整支撑点以适应不同重量和尺寸的平尾,以及如何进行运输和对接。操作流程部分可能会包含操作步骤、安全措施、维护保养等。 4. 应用案例分析:可能包含实际操作中遇到的问题和解决方案,或是对不同机型平尾装配过程的支撑系统应用案例的详细描述,以此展示系统的实用性和适应性。 5. 技术参数和性能指标:列出支撑系统的具体技术参数,如载重能力、尺寸规格、工作范围、可调节范围、耐用性和可靠性指标等,以供参考和评估。 6. 安全和维护指南:对于支撑系统的使用安全提供指导,包括操作安全、应急处理、日常维护、定期检查和故障排除等内容。 该支撑系统作为专门针对平尾装配而设计的设备,对于飞机制造企业来说,掌握其详细信息是提高生产效率和保障产品质量的重要一环。同时,这种支撑系统的设计和应用也体现了现代工业在专用设备制造方面追求高效、安全和精确的趋势。"
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

MATLAB遗传算法探索:寻找随机性与确定性的平衡艺术

![MATLAB多种群遗传算法优化](https://img-blog.csdnimg.cn/39452a76c45b4193b4d88d1be16b01f1.png) # 1. 遗传算法的基本概念与起源 遗传算法(Genetic Algorithm, GA)是一种模拟自然选择和遗传学机制的搜索优化算法。起源于20世纪60年代末至70年代初,由John Holland及其学生和同事们在研究自适应系统时首次提出,其理论基础受到生物进化论的启发。遗传算法通过编码一个潜在解决方案的“基因”,构造初始种群,并通过选择、交叉(杂交)和变异等操作模拟生物进化过程,以迭代的方式不断优化和筛选出最适应环境的
recommend-type

如何在S7-200 SMART PLC中使用MB_Client指令实现Modbus TCP通信?请详细解释从连接建立到数据交换的完整步骤。

为了有效地掌握S7-200 SMART PLC中的MB_Client指令,以便实现Modbus TCP通信,建议参考《S7-200 SMART Modbus TCP教程:MB_Client指令与功能码详解》。本教程将引导您了解从连接建立到数据交换的整个过程,并详细解释每个步骤中的关键点。 参考资源链接:[S7-200 SMART Modbus TCP教程:MB_Client指令与功能码详解](https://wenku.csdn.net/doc/119yes2jcm?spm=1055.2569.3001.10343) 首先,确保您的S7-200 SMART CPU支持开放式用户通
recommend-type

MAX-MIN Ant System:用MATLAB解决旅行商问题

资源摘要信息:"Solve TSP by MMAS: Using MAX-MIN Ant System to solve Traveling Salesman Problem - matlab开发" 本资源为解决经典的旅行商问题(Traveling Salesman Problem, TSP)提供了一种基于蚁群算法(Ant Colony Optimization, ACO)的MAX-MIN蚁群系统(MAX-MIN Ant System, MMAS)的Matlab实现。旅行商问题是一个典型的优化问题,要求找到一条最短的路径,让旅行商访问每一个城市一次并返回起点。这个问题属于NP-hard问题,随着城市数量的增加,寻找最优解的难度急剧增加。 MAX-MIN Ant System是一种改进的蚁群优化算法,它在基本的蚁群算法的基础上,对信息素的更新规则进行了改进,以期避免过早收敛和局部最优的问题。MMAS算法通过限制信息素的上下界来确保算法的探索能力和避免过早收敛,它在某些情况下比经典的蚁群系统(Ant System, AS)和带有局部搜索的蚁群系统(Ant Colony System, ACS)更为有效。 在本Matlab实现中,用户可以通过调用ACO函数并传入一个TSP问题文件(例如"filename.tsp")来运行MMAS算法。该问题文件可以是任意的对称或非对称TSP实例,用户可以从特定的网站下载多种标准TSP问题实例,以供测试和研究使用。 使用此资源的用户需要注意,虽然该Matlab代码可以免费用于个人学习和研究目的,但若要用于商业用途,则需要联系作者获取相应的许可。作者的电子邮件地址为***。 此外,压缩包文件名为"MAX-MIN%20Ant%20System.zip",该压缩包包含Matlab代码文件和可能的示例数据文件。用户在使用之前需要将压缩包解压,并将文件放置在Matlab的适当工作目录中。 为了更好地理解和应用该资源,用户应当对蚁群优化算法有初步了解,尤其是对MAX-MIN蚁群系统的基本原理和运行机制有所掌握。此外,熟悉Matlab编程环境和拥有一定的编程经验将有助于用户根据个人需求修改和扩展算法。 在实际应用中,用户可以根据问题规模调整MMAS算法的参数,如蚂蚁数量、信息素蒸发率、信息素增量等,以获得最优的求解效果。此外,也可以结合其他启发式或元启发式算法,如遗传算法、模拟退火等,来进一步提高算法的性能。 总之,本资源为TSP问题的求解提供了一种有效的算法框架,且Matlab作为编程工具的易用性和强大的计算能力,使得该资源成为算法研究人员和工程技术人员的有力工具。通过本资源的应用,用户将能够深入探索并实现蚁群优化算法在实际问题中的应用,为解决复杂的优化问题提供一种新的思路和方法。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依
recommend-type

【实战指南】MATLAB自适应遗传算法调整:优化流程全掌握

![MATLAB多种群遗传算法优化](https://img-blog.csdnimg.cn/39452a76c45b4193b4d88d1be16b01f1.png) # 1. 遗传算法基础与MATLAB环境搭建 遗传算法(Genetic Algorithm, GA)是模拟生物进化过程的搜索启发式算法,它使用类似自然选择和遗传学的原理在潜在解空间中搜索最优解。在MATLAB中实现遗传算法需要先搭建合适的环境,设置工作路径,以及了解如何调用和使用遗传算法相关的函数和工具箱。 ## 1.1 遗传算法简介 遗传算法是一种全局优化算法,它的特点是不依赖于问题的梯度信息,适用于搜索复杂、多峰等难