- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我需要制作一个利用 3 向分区的快速排序方法。我正在使用的算法可以在这里找到 https://algs4.cs.princeton.edu/lectures/23DemoPartitioning.pdf向下滚动到 Dijkstra 3 向分区演示。对于某些数组,例如 5 5 7 3 5 1 6 2 4 8,我的方法有效。但是,当我放置诸如 5 5 7 3 5 1 6 2 4 8 9 8 之类的数组时,我的代码无法正常工作。我得到输出:1 2 3 4 5 5 5 6 7 8 9 8。我知道问题出在哪里,但我不明白为什么我的代码没有处理它。这是我的代码:
import java.util.Scanner;
public class QuickSortDriver {
public static void main(String[] args)
{
Scanner scan = new Scanner(System.in);
System.out.print("\n\nEnter array elements: ");
String s = scan.nextLine();
String[] token = s.split(" ");
int[] array = new int[token.length];
for(int i=0; i < array.length; i++)
array[i] = Integer.parseInt(token[i]);
quicksort(array, 0, array.length - 1);
System.out.print("\nSorted array: ");
for(int i = 0; i < array.length; i++)
System.out.printf("%d ", array[i]);
System.out.print("\n\n");
scan.close();
}
public static void quicksort(int [] array, int low, int high)
{
//debugging: shows what the array is
//before the while loop
System.out.print("\n");
for(int j = low; j <= high; j++)
System.out.printf("%d ", array[j]);
if(high <= low)
return;
int lt = low;
int gt = high;
int i = low;
while(i <= gt)
{
if(array[i] < array[low])
swap(array, lt++, i++);
else if(array[i] > array[low])
swap(array, i, gt--);
else
i++;
}
//debugging: shows what the array is
//after the while loop
System.out.print("\n");
for(int j = low; j <= high; j++)
System.out.printf("%d ", array[j]);
quicksort(array, low, lt -1);
quicksort(array, gt + 1, high);
}
public static void swap(int array[], int i, int j)
{
int tmp = array[i];
array[i] = array[j];
array[j] = tmp;
}
}
出于调试目的,我将打印数组的 for 循环放在排序方法的开头和结尾,通过这样做我发现了问题。这是我的输入输出,其中打印了调试语句:
Enter array elements: 5 5 7 3 5 1 6 2 4 8 9 8
5 5 7 3 5 1 6 2 4 8 9 8
4 3 2 1 5 5 6 5 8 9 8 7
4 3 2 1
3 2 1 4
3 2 1
2 1 3
2 1
1 2
1
6 5 8 9 8 7
5 6 9 8 7 8
5
9 8 7 8
8 7 9 8 <--right here is the problem
8 7
7 8
7
Sorted array: 1 2 3 4 5 5 5 6 7 8 9 8
当我的程序到达数组的 9 8 7 8 部分时,它应该这样做:
(请遵循Dijkstra 3路划分算法中的逻辑。)
9 8 7 8
i = 9 lt = 9 gt = 8(at end) increment i
9 8 7 8
i = 8 lt = 9 gt = 8(at end) swap i and lt and increment i
8 9 7 8
i = 7 lt = 9 gt = 8(at end) swap i and lt and increment i
8 7 9 8
i = 8(at end) lt = 9 gt = 8(at end) 现在,它应该交换 i 和 lt 并递增 i。但是,它没有,我不知道为什么。我的 while 循环中的条件是 while(i <= gt),因此它应该在那个点继续迭代,因为 i 和 gt 位于相同的索引处(请参阅代码),但事实并非如此。如果这里有人可以帮助我修复这个错误,我将不胜感激,我真的要开始拔头发了。
最佳答案
尝试在 while 循环中使用 lt
而不是 low
。它应该看起来像这样:
while(i <= gt)
{
if(array[i] < array[lt])
swap(array, lt++, i++);
else if(array[i] > array[lt])
swap(array, i, gt--);
else
i++;
}
关于java - Quicksort 3 方式分区代码没有按要求执行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47284418/
我有一个类和构造函数,如下所示: def init(log, edge): if edge: return Helper(log, edge) return Booka
关闭。这个问题需要更多focused .它目前不接受答案。 想改善这个问题吗?更新问题,使其仅关注一个问题 editing this post . 4年前关闭。 Improve this questi
有人知道在 mongo 上安装标准 ubuntu 需要多少磁盘空间和内存吗?试图找出我的 VPS 需求... 最佳答案 没有最低要求,但我不建议在与您的网络服务器相同的机器上运行 Mongo。 Mon
我的 Django 项目有一个虚拟环境,但是当我 pip 击 pip freeze 时,我得到了一个必须是全局站 pip 包列表的东西,包括太多包,比如ubuntu包和这么多不相关的东西。无论 vir
我曾尝试在 Heroku 上部署我的应用程序,但 smth 出错了。 错误:找不到满足要求的版本 get==2019.4.13(来自 -r/tmp/build_53ad6d03_/requiremen
我无法将 semantic-ui-calendar npm 模块加载到我的应用程序中。 我已经使用脚本标签成功地将它加载到我的 HTML 中, 但每次我尝试将它加载到我的应用程序中时,我都会出错。 在
如何修复 php.ini 中“require”函数内的地址?它进行故障排除并显示错误: 警告:require (..) 无法打开流:没有这样的文件或目录。 文件“db_connection.php”工
我有一个在 Node.js 应用程序中使用的外部库 ( Objection.js )。我创建了一个基本模型类,它为我的实体模型扩展了 Objection 的 Model 类: const { Mode
有谁知道在哪里可以找到RHEL5的GLIBC2.7,如果没有这个,Android模拟器将无法启动。它会给出一条消息,要求GLIBC 2.7或更高版本。 我尝试在网上搜索,但没有找到 最佳答案 我也遇到
Android 设备是否有任何要求/指南?例如按钮数量或所需的最少按钮数量。 还有没有菜单和后退按钮的安卓设备吗? (我知道就可用性而言,没有菜单/后退按钮会杀死大多数应用程序,我只是想了解更多有关该
我想要求/包含一个文件并将其内容检索到一个变量中。 test.php index.php ".$test; ?> 类似于 file_get_contents() 但它仍应执行 PHP 代码。这可能吗
我想要求/包含一个文件并将其内容检索到一个变量中。 test.php index.php ".$test; ?> 类似于 file_get_contents() 但它仍应执行 PHP 代码。这可能吗
我正在尝试在我的 Linux Mint 发行版上安装一个 python 模块“pyAudioProcessing”(https://github.com/jsingh811/pyAudioProces
我已经创建了我的第一个 composer 包,它具有 MySQL 和 MongoDB 的功能,但是,它不需要两者。我意识到有人可能只想将这个包与两个数据库之一一起使用,目前我有: "require":
我想调试以下函数,但假设在调试器中查看 moreajaj 的参数等于什么(假设不像在这个人为的示例中那么明显)是有用的。我可以在调试器框架中打印它,但是在每个参数的每个框架中都这样做很烦人。在宣布每一
我有一些生成的 GNUmakefiles,我需要从中提取变量的值。 有没有一种简单的方法可以在不修改 makefile 的情况下查看变量的值? 仅供引用,变量包含 emacs c-macro-expa
我正在使用 aspell 在 Linux 上拼写检查 LaTeX 文档。我的文档经常包含各种编程语言的代码示例,我希望 aspell 在拼写检查时简单地跳过这些行。 我可以在文档中写些什么来关闭一段文
我有一个包含多个列的数据集... 一列是具有重复值的主石斑鱼列,另一列是具有 bool 值 (1,0) 的 NUMBER,如下所示: grp bool --- ---- A 1 A 1 A
出于测试目的,我正在尝试删除一些 amd 模块并从服务器重新加载更新版本 - 目的是不刷新浏览器。 我目前正在执行以下操作,但浏览器仍然没有从网络重新加载项目。 var scripts = docum
当我键入irb> require 'rubygems'时,它返回false。我的Rails应用程序中有很多 gem ,这些 gem 显然可以正常工作-耙子,activerecord等。这里可能出什么问
我是一名优秀的程序员,十分优秀!