- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
在一些情况下,能够比较二叉搜索树中的最后一个元素和第一个元素,元素对,将被证明是有用的。
例如:找到 2 个总和为给定数字的元素。 (最快的方法是尝试将最小和最大的数字相加,然后根据与给定数字的结果总和推进每一端)
^我知道这可以通过使用 2 个堆栈以迭代 方式遍历树来完成。我只是在想是否有一种方法可以使用 2 线程 来做这样的事情:
pthread_mutex_t MTree1, Mtree2;
pthread_t thread[2];
pthread_attr attr;
int data1, data2;
int tempInorder, tempRevInorder;
int requiredSUM
void mergBST(node*root)
{
pthread_mutex_init(&Mtree1, NULL);
pthread_mutex_init(&Mtree2, NULL);
pthread_attr_setdetachestate(&attr,PTHREAD_CREATE_JOINABLE);
pthread_create(&thread[0],&attr, mergeBSTImplInOrder, void*(root));
pthread_create(&thread[1],&attr, mergeBSTImplRevInOrder, void*(root));
}
void mergeBSTImplInOrder(void *root)
{
root=(node*) root;
if(!root) return;
mergeBSTImpl(root->left);
tempInorder=root->data
/*This is where there has to be conditional checks such that execution would stop right here so I can compare varables **tempInorder** **tempRevInorder** with the variable "requiredSUM"*/
mergeBSTImpl(root->right);
}
void mergeBSTImplRevInOrder(void *root)
{
root=(node*) root;
if(!root) return;
mergeBSTImpl(root->right);
tempRevInorder=root->data;
//A similar situation as the other function.
mergeBSTImpl(root->left);
}
那么...我尝试做的事情在逻辑上是否可行?这是我在 stackoverflow 中的第一篇文章。我希望我把格式和事情弄对了。如果没有,请客气。 =)
堆栈方法至少占用O(logm + logn) 空间。线程方式实际上可以用更简单的代码和 O(1) 空间
来完成2 functions, each running it's own thread:
Fn1(say): One, a function that recurses in an Inorder fashion.
Fn2(say): Two, a function that recurses in a reverse Inorder fashion.Each time either of the function reads data from the BST, it stores them in static variables, and it has to check if two elements saved from the 2 functions are there to compare. One from itself, the other from the other function. if there are 2 elements yet, then it finds the sum of the elements with requiredSUM. In case the sum of variable is bigger, it lets the other function continue till it gets the next one (which would be the second smallest element). This function stays till the other function gets its new element. Comparison takes place. If this time, the sum is smaller than requiredSUM, this function carries on and the other function waits till this function gets the next element (the 2nd smallest element). Comparison takes place and this goes on till the 2 elements summing to the required target Sum is found.
这是一种算法,用于查找排序数组中总和为指定值的所有整数对。除了 我们现在有 BST 而不是排序数组。只是为了展示,我将通过以下方式解决问题的数组版本:
#include <iostream>
#include <algorithm>
using namespace std;
void print_pairs(int * ptr, int num, int sum)
{
std::sort(ptr, ptr + num);
int first = 0;
int last = num - 1;
while (first < last)
{
int s = ptr[first] + ptr[last];
if (s == sum)
{
//cout<<ptr[first]<<“ “<< ptr[last]<<endl;
++first;
--last;
}
else
{
if (s < sum)
++first;
else
--last;
}
}
}
int main()
{
int test[] = {9, 3, 6, 5, 7, -1, 13, 14, -2, 12, 0};
print_pairs(test, sizeof(test) / sizeof(int), 12);
return 0;
}
最佳答案
我的感觉是线程 不能解决您的问题。保持前后遍历状态的两个游标状态或类似迭代器的对象将为您提供相同的结果。
线程是一种协调执行的方式,而不是一种分割代码的方式。在任何情况下,您都应该尽可能避免使用线程,在这种情况下(线程永远不会同时运行),线程不会为解决方案增加值(value)
如果你硬要说,那你要的就是条件变量。
条件是一个线程将阻塞直到其他线程发出继续信号的位置。条件链接到互斥量。
所以在 thread1 上你会:
thread1stopped=false; // let this start running
while (true) {
pthread_mutex_lock(&mutex2); // lock on the other thread mutex
while(!thread2stopped) {
pthread_cond_wait(&cond2, &mutex2); // wait for the signal
}
pthread_mutex_unlock(&mutex2); // unlock the other thread mutex
// Now we're running:
// ... do whatever I need to do
// ... until I need to stop.
pthread_mutex_lock(&mutex1); // lock my mutex
thread1stopped=true; // change the state
pthread_cond_signal(&cond1); // signal to the other thread
pthread_mutex_unlock(&mutex1); // unlock my mutex
pthread_mutex_lock(&mutex1); // lock my mutex
thread1stopped=false;
pthread_mutex_unlock(&mutex1); // unlock my mutex
}
另一个可以
thread2stopped=true; // let this start stopped
while (true) {
pthread_mutex_lock(&mutex1); // lock on the other thread mutex
while(!thread1stopped) {
pthread_cond_wait(&cond1, &mutex1); // wait for the signal
}
pthread_mutex_unlock(&mutex1); // unlock the other thread mutex
// Now we're running:
// ... do whatever I need to do
// ... until I need to stop.
pthread_mutex_lock(&mutex2); // lock my mutex
thread2stopped=true; // change the state
pthread_cond_signal(&cond2); // signal to the other thread
pthread_mutex_unlock(&mutex2); // unlock my mutex
pthread_mutex_lock(&mutex2); // lock my mutex
thread2stopped=false;
pthread_mutex_unlock(&mutex2); // unlock my mutex
}
这个有效:
Thread1 Thread2
. .
-------- --------
| exec | | lock1| thread1stopped==false
| | | wait | (wait unlocks)
-------- | |
. | |
-------- | |
|lock1 | | |
|true | | |
|signal|---------->|unlock|
-------- --------
. .
-------- --------
| lock2| | exec |
| wait | | |
| | --------
| | .
| | --------
| | |lock2 |
| | |true |
|unlock|<----------|signal|
-------- --------
还没有真正尝试过这段代码,所以可能存在问题、死锁、竞争条件......但我希望它能给你一个起点。
关于c++ - 通过 "inorder"和 "reverse inorder"方法同时遍历二叉搜索树的多线程方法,比较元素对,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28897534/
我想使用 NetworkX Graph 对象作为 Python dict 中的键。但是,我不希望默认的比较行为(即通过对象的地址)。相反,我希望同构图是 dict 中相同元素的键。 此行为是否已在某处
这个问题已经有答案了: What is the most effective way for float and double comparison? (33 个回答) 已关闭 7 年前。 在您认为我
我正在学习 C 编程,为了练习,我找到了一个需要解决的任务。这有点像一个游戏,有人选择一个单词,其他人猜测字母。我必须检查有多少给定的单词可能是所选单词的正确答案。 输入: 3 3//数字 n 和 m
我两天前开始学习C,在做作业时遇到了问题。我们的目的是从字符数组中获取字符列表,并通过计算连续字符并将其替换为数字来缩短它。对“a4b5c5”说“aaaabbbbbccccc”。这是我到目前为止的代码
已关闭。此问题需要 debugging details 。目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and the
为什么我在 if 中的比较不起作用?答案应该是 8 但它返回 0。 function findMissing(missingArray){ var getArray = missing
我想知道为什么以下 JavaScript 比较会给出不同的结果。 (1==true==1) true (2==true==2) false (0==false==0) false (0==false)
我想知道是否有人可以帮助我完成这个程序。编写一个接受两个字符串的函数。该函数应该将这两个字符串与字典顺序上排在第一位的字符串组合起来。两个字符串之间应该有一个空格。在一行上打印结果字符串。在一行上打印
有谁知道一个免费的开源库(实用程序类),它允许您比较一个 Java bean 的两个实例并返回一个属性列表/数组,这两个实例的值不同?请发布一个小样本。 干杯 托马斯 最佳答案 BeanCompara
我是java新手。任何人都可以给出以下类声明的含义 public class ListNode, V> { K key; V value; ListNode next;
我需要用 C 语言计算和比较 3 种不同大小(100 * 100、1000 * 1000 和 10000 * 10000)的 2 个矩阵相乘的执行时间。我编写了以下简单代码来为 1000 * 1000
当我在 ACCESS 2007 中运行以下 SQL 时 Select Location, COUNT(ApartmentBuildings) AS TotalIBuildingsManaged Fro
根据我对互斥锁的了解——它们通常提供对共享资源的锁定功能。因此,如果一个新线程想要访问这个锁定的共享资源——它要么退出,要么必须不断轮询锁(并在等待锁时浪费处理器周期)。 但是,监视器具有条件变量,它
通常在编程中,不应该比较浮点数据类型是否相等,因为存储的值通常是近似值。 由于两个非整数 Oracle NUMBER 值的存储方式不同(以 10 为基数),是否可以可靠地比较它们是否相等? 最佳答案
使用 PowerShell 时,我们偶尔会比较不同类型的对象。一个常见的场景是 $int -eq $bool (即其中 0 -eq $false 、 0 -ne $true 和任何非零值仅等于真,但不
#include #define MAX 1000 void any(char s1[], char s2[], char s3[]); int main() { char string1[
我想比较两个日期。 从这两个日期中,我只使用 ToShortDateString() 获取日期组件, 如下所示。现在的问题是当我比较两个日期时。它的 throw 错误—— "Operator >= c
用户输入一个数字( float 或整数),并且它必须大于下限。 这是从 UITextField 获取数字的代码: NSNumberFormatter * f = [[NSNumberFormatter
我已经摆弄这段代码大约一个小时了,它让我难以置信。我认为解决方案相当简单,但我似乎无法弄清楚。无论如何,这里去。我制作了一个 javascript 函数来检查用户输入的字符,以便它只能接受 7 个字符
我不太明白为什么当我们在不覆盖 equals 的情况下比较具有相同类属性的两个实例时方法,它将给出 false .但它会给出 true当我们比较一个案例类的两个实例时。例如 class A(val
我是一名优秀的程序员,十分优秀!