- android - 多次调用 OnPrimaryClipChangedListener
- android - 无法更新 RecyclerView 中的 TextView 字段
- android.database.CursorIndexOutOfBoundsException : Index 0 requested, 光标大小为 0
- android - 使用 AppCompat 时,我们是否需要明确指定其 UI 组件(Spinner、EditText)颜色
正如上面的标题所说,我出于某种原因编写的二分查找函数无法找到给定的数字,如果它位于数组的末尾或开头。我曾尝试在调试器中寻找问题,但没有出现任何异常情况。
例如,如果您输入 24 25 26 27 28
而它试图查找的数字是 28,它将返回 false
。
但是如果数字是 24 25 28 26 30
它将返回 true
(假设这些数字已经预先排序)
bool search(int value, int values[], int n)
{
// check if only 1 item exists in values and if it is the item which is being looked for
if (n == 1)
{
if (value == values[0]) return true;
else return false;
}
int middle = n / 2;
// if the value is greater than middle, search the right half of the array
if (value > values[middle])
{
// initialize rightHalf since it is a variable length array
int rightHalf[n];
for(int x = 0; x <= n; x++) rightHalf[x] = 0;
int rightHalfSize = n - middle;
if (value > values[middle])
{
int rightHalfSize = n - middle - 1;
for (int i = 0, m = middle + 1; i < rightHalfSize; i++, m++)
{
rightHalf[i] = values[m];
}
}
return search(value, rightHalf, rightHalfSize);
} // if the value is less than middle, search the left half of the array
else if (value < values[middle])
{
// initialize leftHalf since it is a variable length array
int leftHalf[n];
for(int y = 0; y <= n; y++) leftHalf[y] = 0;
int leftHalfSize = n - middle;
for (int i = 0, m = 0; i < middle; i++, m++)
{
leftHalf[i] = values[m];
}
return search(value, leftHalf, leftHalfSize);
}
else if (value == values[middle]) return true;
return false;
}
最佳答案
目前尚不清楚在函数中创建一个可变长度数组的目的,该数组至少会由于循环而导致未定义的行为
int rightHalf[n];
for(int x = 0; x <= n; x++) rightHalf[x] = 0;
因为有人试图改变数组之外的内存,让 x 等于 n。
确定目标值是否存在的函数可以写得更简单。
例如
#include <stdio.h>
#include <stdbool.h>
bool search( const int a[], size_t n, int value )
{
if ( !n )
{
return false;
}
else
{
size_t middle = n / 2;
if ( a[middle] < value )
{
return search( a + middle + 1, n - middle - 1, value );
}
else if ( value < a[middle] )
{
return search( a, middle, value );
}
else
{
return true;
}
}
}
int main(void)
{
int a[] = { 24, 25, 26, 27, 28 };
const size_t N = sizeof( a ) / sizeof( *a );
printf( "a[0] - 1 is found - %d\n", search( a, N, a[0] - 1 ) );
for ( size_t i = 0; i < N; i++ )
{
printf( "a[%zu] is found - %d\n", i, search( a, N, a[i] ) );
}
printf( "a[%zu] + 1 is found - %d\n", N - 1, search( a, N, a[N-1] + 1 ) );
return 0;
}
程序输出为
a[0] - 1 is found - 0
a[0] is found - 1
a[1] is found - 1
a[2] is found - 1
a[3] is found - 1
a[4] is found - 1
a[4] + 1 is found - 0
关于c - 如果指定数字位于排序数组的末尾或开头,则二进制搜索函数无法找到它们,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46758185/
我正在更改链接网址以添加 www.site.com/index.html?s=234&dc=65828 我通过此代码得到的是:site.com/&dc=65828 var target="&dc=65
我在编译过程中收到错误: src/smtp.c:208:1: warning: control reaches end of non-void function [-Wreturn-type] 这是相
这是我的 bootstrap/html 代码: Put email 位置正确,但我希望输入字段的大小延伸到 div 末尾。谁能帮帮我? 最佳答案 只需按百分比指定宽度,如下所示
我正在尝试获取一个像这样的 json 对象: filters = {"filters": myArray}; 并将其附加到 URL 的末尾,使用: this.router.navigate([`/de
这个问题已经有答案了: Remove hash from url (5 个回答) 已关闭 10 年前。 我有一个网站,stepaheadresidents.com ,并且井号 (#) 会自动添加到 u
我有这个代码 $('container a').appendTo('.container'); dzedzdqdqdqzdqdzqdzqdqzdqd Forgot password
为了练习更多 Python 知识,我尝试了 pythonchallenge.com 上的挑战 简而言之,作为第一步,此挑战要求从末尾带有数字的 url 加载 html 页面。该页面包含一行文本,其中有
我对 FS2 很陌生,需要一些有关设计的帮助。我正在尝试设计一个流,它将从底层的 InputStream 中提取 block ,直到结束。这是我尝试过的: import java.io.{File,
我对 FS2 很陌生,需要一些有关设计的帮助。我正在尝试设计一个流,它将从底层的 InputStream 中提取 block ,直到结束。这是我尝试过的: import java.io.{File,
我正在编写一个 ajax 应用程序,并且在 php 脚本中有一个函数: public function expire_user() { $r=array("return"=>'OK');
我正在使用一个QListView,它包装了一个非常简单的列表模型。我想尝试实现类似于某些网页中看到的“无限滚动”的东西。 目前,模型通过最多添加 100 个项目的方法更新(它们取自外部 Web API
运行 cucumber 测试给我以下错误 end of file reached (EOFError) /usr/lib64/ruby/2.0.0/net/protocol.rb:153:in
按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visit the
我想知道版本命名的具体作用是什么? 喜欢 jquery.js?ver=1.4.4 我的意思是如果我使用像这样的 cdn jquery/1.4.4/jquery.min.js?ver=1.4.4但是另一
" data-fancybox-group="gallery" title="">" alt="" /> 在此代码中 echo $prod['item_image_url'];打印存储在我的表中的图像
我目前使用 Wordpress 作为博客平台,但我想更改为使用 Jekyll 来生成静态页面。在 WordPress 上,我的 URL 使用以下格式: /年/月/日/标题 但我想将其重定向到 /年/月
根据docs这应该是不可能的 Regular expressions cannot be anchored to the beginning or end of a token 尽管如此,它似乎对我有
有没有办法创建 dijit 并将其附加到 div 的末尾?假设我有以下代码: Add Person 我在网上找到了以下代码,但这替换了我的“attendants”div: var personCo
我有这段代码: //execute post (the result will be something like {"result":1,"error":"","id":"4da775
我需要一些函数方面的帮助。 我想编写一个插入链表的函数。但不仅仅是中间,如果必须插入前端或末尾,它也必须起作用。 结构: typedef struct ranklist { i
我是一名优秀的程序员,十分优秀!