当前位置: 首页>>代码示例>>C++>>正文


C++ AVLTree类代码示例

本文整理汇总了C++中AVLTree的典型用法代码示例。如果您正苦于以下问题:C++ AVLTree类的具体用法?C++ AVLTree怎么用?C++ AVLTree使用的例子?那么, 这里精选的类代码示例或许可以为您提供帮助。


在下文中一共展示了AVLTree类的15个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。

示例1: main

int main(){
	AVLTree<int>* tree = new AVLTree<int>;

	for (int i = 0; i < 10; i++){
		int* toInsert = new int(rand()%200);
		std::cout<<"inserting:"<<*toInsert<<std::endl;
		tree->insert(toInsert);
		// tree->printTree(AVLTree<int>::PRE_ORDER_TRAVERSAL);
		// std::cout<<"**** INSERT ****\n"<<std::endl;
	}

	std::cout<<"\n----------- INSERTED ------------"<<std::endl;
	tree->printTree(AVLTree<int>::PRE_ORDER_TRAVERSAL);

	int del = 0;

	std::cout<<"\n----------- TO ERASE ------------"<<std::endl;
	while(del != -1){
		std::cout<<"Digite un número para borrar"<<std::endl;
		cin>>del;
		std::cout<<"----.----"<<std::endl;
		tree->erase(&del);
		//tree->insert(new int(del));
		tree->printTree(AVLTree<int>::PRE_ORDER_TRAVERSAL);
	}

	return 0;
}
开发者ID:jloaiza,项目名称:dugtrio,代码行数:28,代码来源:main.cpp

示例2: demo2

void demo2(int n, double lf) {
    //generate random strings
    fp = fopen("test2.txt", "w");
    string *v = new string[n + 10];
    time_t t1;
    AVLTree<string, bool> used;
    OpenStrHashTable<int> openhash(ceil((double)n / lf));
    ListStrHashTable<int> listhash(ceil((double)n / lf));
    cout << "Generating data:" << endl;
    for (int i = 1; i <= n; ) {
        string s;
        int len = ceil(log(n)/log(3)) + rand() % 15; // min length satisfying(3^len>n) +- 3
        for (int j = 1; j <= len; ++j)
            s += (33 + rand()%(127-33));
        if (used.hasKey(s)) {
            //cout << "duplicate key:" << s << endl;
            continue;
        }
        else {
            fprintf(fp, "%s", s.c_str());
            v[i++] = s;
            used.insert(s, true);
        }
    }
    cout << "Generation finished." << endl;
    
    cout << "Inserting all (key = string, value = length) pairs to OpenStrHashTable..." << endl;
    t1 = clock();
    openhash.clearcrash();
    for (int i = 1; i <= n; i++)
        openhash.insert(v[i], v[i].length());
    t1 = clock() - t1;
    cout << "Crashes: " << openhash.crashcount << ", Time used: " << (double)t1/CLOCKS_PER_SEC << endl;
    
    cout << "Searching all keys in OpenStrHashTable..." << endl;
    t1 = clock();
    openhash.clearcrash();
    for (int i = 1; i <= n; i++)
        openhash.get(v[i]);
    //cout << v[i] << ": " << openhash.get(v[i]) << endl;
    t1 = clock() - t1;
    cout << "Crashes: " << openhash.crashcount << ", Time used: " << (double)t1/CLOCKS_PER_SEC << endl;
    
    cout << "Inserting all (key = string, value = length) pairs to ListStrHashTable..." << endl;
    listhash.clearcrash();
    t1 = clock();
    for (int i = 1; i <= n; i++)
        listhash.insert(v[i], v[i].length());
    t1 = clock() - t1;
    cout << "Crashes: " << listhash.crashcount << ", Time used: " << (double)t1/CLOCKS_PER_SEC << endl;
    
    cout << "Searching all keys in ListStrHashTable..." << endl;
    t1 = clock();
    listhash.clearcrash();
    for (int i = 1; i <= n; i++)
        listhash.get(v[i]);
    //cout << v[i] << ": " << listhash.get(v[i]) << endl;
    t1 = clock() - t1;
    cout << "Crashes: " << listhash.crashcount << ", Time used: " << (double)t1/CLOCKS_PER_SEC << endl;
}
开发者ID:Xivid,项目名称:Software-Design-and-Development-Practice-I,代码行数:60,代码来源:main.cpp

示例3: main

int main()
{
    AVLTree<char> Tree;
    
    std::string input("ABCDEF"), str;
    for( auto x: input )
        Tree.add(x);
        
    
    // std::function<void(const char& )> visit = 
                        // []( const char& x)
                        // { std::cout << x << ' '; } ;
    // Tree.display (visit ) ;
    
    std::function<void(const char& )> visit1 = 
                        [&str]( const char& x)
                        { str+=x; } ;
                        
    Tree.display ( visit1 ) ;
    
    assert( str == "DBEACF" ); 
    assert( Tree.count() == input.length() );
    assert( Tree.contains('E') == true ); 
    assert( Tree.contains('X') == false ); 
    
    return 0;
}
开发者ID:CCJY,项目名称:coliru,代码行数:27,代码来源:main.cpp

示例4: main

int
main() {
  AVLTree<int>	t;

  std::cout << "ajout de 1" << std::endl;;
  t.push(1);
  /*  std::cout << std::endl << std::endl << "ajout de -10" << std::endl;
  t.push(-10);

  std::cout << std::endl << std::endl << "ajout de -11" << std::endl;
  t.push(-9);
  */
  /*std::cout << "ajout de -12" << std::endl;
  t.push(-12);
  */
  /*std::cout << "ajout de -13" << std::endl;
    t.push(-13);*/

  std::cout << "ajout de 15" << std::endl;
  t.push(15);
  std::cout << "ajout de 10" << std::endl;
  t.push(10);

  /*
    std::cout << "ajout de 21" << std::endl;
    t.push(21);
    std::cout << "ajout de 23" << std::endl;
    t.push(23);
  */
  //t.push(1);
  t.applyToTree(display);
}
开发者ID:chiwawa,项目名称:AVLTree,代码行数:32,代码来源:main.cpp

示例5: Remove

/*
 * removal
 */
int
AVLTree::Remove (AVLTree * &racine, bool rebalance)
{
  AVLTree *startNode = NULL;
  int remDiff = 0;
  int res = Remove (racine, startNode, remDiff);
  if (res == avl_no_err && rebalance && startNode)
    res = startNode->RestoreBalances (remDiff, racine);
  return res;
}
开发者ID:AakashDabas,项目名称:inkscape,代码行数:13,代码来源:AVL.cpp

示例6: main

int main(){

	cout<<"AVL Tree\n";
	int arr[] = {5,4,3,6,8,2,1};
	cout<<"Print elements :";
	for(int i=0;i<7;i++)
		cout<<arr[i]<<" ";
	cout<<"\n\n";
	AVLTree<int> a;
	
	for(int i=0;i<7;i++)
		a.insert(arr[i]);
	cout<<"PreOrder :";
	a.preOrder();
	cout<<"\nInOrder :";
	a.inOrder();
	cout<<"\nPostOrder :";
	a.postOrder();
  
  cout<<"Remove 6\n";
  a.remove(6);
  cout<<"PreOrder :";
	a.preOrder();
	cout<<"\nInOrder :";
	a.inOrder();
	cout<<"\nPostOrder :";
	a.postOrder();
	return 0;
}
开发者ID:himkwan01,项目名称:TszKwan_CSC17C_48942,代码行数:29,代码来源:main.cpp

示例7: TEST

TEST(AVLTree, Insert) {
  {
  AVLTree<int, int> a;

  for (int i = 0; i < 1000; i++) {
    a.Insert(i, i * i);
    for (int k = 0; k <= i; k++) {
      ASSERT_EQ(a.Find(k).first, k * k);
      ASSERT_TRUE(a.Find(k).second);
    }
  }
  }
  {
  AVLTree<int, int> a;

  for (int i = 100; i > 0; i--) {
    a.Insert(i, i * i);
    for (int k = i; k <= 100; k++)
      ASSERT_EQ(a.Find(k).first, k * k);
  }
  }
  AVLTree<int, int> b;
  mt19937_64 _e1(chrono::system_clock::now().time_since_epoch().count());
  std::uniform_int_distribution<int> dist(0, 1000000);
  for (int i = 0; i < 1000; i++) {
    int t = dist(_e1);
    b[t] = i * i;
    ASSERT_EQ(b.Find(t).first, i * i);
  }
}
开发者ID:Zaspire,项目名称:libshelly,代码行数:30,代码来源:avl_tree_test.cpp

示例8: TestAVLTree

void TestAVLTree()
{
	int arr[] = { 4, 2, 6, 1, 3, 5, 15, 7, 16, 14 };
	// int arr[] = { 16, 3, 7, 11, 9, 26, 18, 14, 15 };
	AVLTree<int, int> tree;
	for (size_t i = 0; i < sizeof(arr) / sizeof(arr[0]); i++)
	{
		tree.Insert(arr[i]);
	}
	tree.InOrder();
}
开发者ID:muhuizz,项目名称:Data_Structure,代码行数:11,代码来源:AVLTree.hpp

示例9: AVLStressSmall

void AVLStressSmall(void)
{
  const char *test = "AVLStressSmall";
  std::cout << "\n====================== " << test << " ======================\n";

  int *ia = 0;
  try
  {
    AVLTree tree;
    int correct_nums[] = {1, 15, 22, 20, 12, 3, 0, 19, 18, 17, 8, 10, 9, 24, 6, 11, 4, 21, 7, 14, 13, 23, 5, 2, 16};
    int size = 25;
    ia = new int[size];
    for (int i = 0; i < size; i++)
      ia[i] = correct_nums[i];

    //Shuffle(ia, size, 1);
    Print(ia, size);

    for (int i = 0; i < size; i++)
    {
      tree.insert(ia[i]);
      //PrintInfo(tree);
      std::cout << "Insert item #" << i << ":" << ia[i] << " =========================================\n";
      PrintBST(tree);
    }

    PrintInfo(tree);
    //PrintBST(tree);

    Shuffle(ia, size, 1);
    for (int i = 0; i < size - 10; i++)
    {
      tree.remove(ia[i]);
      std::cout << "Remove item #" << i << ":" << ia[i] << " =========================================\n";
      PrintBST(tree);
    }
    PrintInfo(tree);
    PrintBST(tree);

    if (tree.ImplementedIndexing())
      for (unsigned i = 0; i < tree.size(); i++)
        std::cout << "Index " << i << ": " << tree[static_cast<int>(i)]->data << std::endl;

  }
  catch(const BSTException& e)
  {
    std::cout << "Exception caught: " << e.what() << std::endl;
  }
  catch(...)
  {
    std::cout << "Unknown exception." << std::endl;
  }
  delete [] ia;
}
开发者ID:HBreithaupt,项目名称:DigiPenCode,代码行数:54,代码来源:driver-sample-ints.cpp

示例10: runTest

void runTest(const vector< pair<K, V> > & elems, const string & filename)
{
    AVLTree<K, V> tree;
	stringstream output;

    tree.setOutput(output);
    for(auto elem = elems.begin(); elem != elems.end(); ++elem)
        tree.insert(elem->first, elem->second);

    tree.print(output);
    ASSERT_TREE_EQUALS(output.str(), filename);
}
开发者ID:Boffee,项目名称:Data-structure,代码行数:12,代码来源:unit_tests.cpp

示例11: main

int main() {
	//freopen("..\\advanced-pat-python\\test.txt", "r", stdin);
	int N;
	cin >> N;
	AVLTree tree;
	int tmp;
	while (N--) {
		cin >> tmp;
		tree.insert(tmp);
	}
	cout << tree.root->value << endl;
}
开发者ID:zhangli0812,项目名称:advanced-pat-cpp,代码行数:12,代码来源:main.cpp

示例12: testRotateRightLeft

void testRotateRightLeft()
{
	AVLTree<int, int> tree;
	printHeader("Right-Left Rotation");
	tree.insert(3, 3);
	tree.insert(8, 8);
	printBefore();
	tree.print();
	printAfter(6);
	tree.insert(6, 6);
	tree.print();
	printEnd();
}
开发者ID:AdonisSaveYourLife,项目名称:cs225,代码行数:13,代码来源:main.cpp

示例13: main

int main(void) {
	int n;
	AVLTree tree;
	scanf("%d", &n);
	for (int i = 0; i < n; i++) {
		int x;
		scanf("%d", &x);
		tree.insert(x);
	}
	printf("%d\n", tree.getRoot());
	system("pause");
	return 0;
}
开发者ID:SnowyOwl-KHY,项目名称:OJ,代码行数:13,代码来源:1066.cpp

示例14: main

int main()
{
	AVLTree T;
	char ch;
	int n;
	while(1)
	{
		cin >> ch ; 
		switch(ch)
		{
			case'I':cin >> n;
				T.insert(n);
				break;
			case'T':T.traverse(T.getroot());
				break;
			case'S':cin >> n;
				cout << T.search(n,T.getroot())<<endl;
				break;
			case'D':cin >> n;
				T.delnode(n);
				break;
			case'R':cout<< T.getroot()->data<<endl;
				break;
			case'X':return 0;
		}
	}
}
开发者ID:vikas-reddy,项目名称:iiith-programming,代码行数:27,代码来源:AVLtree.cpp

示例15: main

int main()
{
	AVLTree al;
	for (int i = 1; i < 10; i ++) {
		al.Insert(i);
		
	}
	al.Print();
	for (int i = 1; i < 10; i += 2) {
		al.Delete(i);
		al.Print();
	}
	return 0;
}
开发者ID:chambakari,项目名称:Introduction-of-Algorithms,代码行数:14,代码来源:AVL_Tree.cpp


注:本文中的AVLTree类示例由纯净天空整理自Github/MSDocs等开源代码及文档管理平台,相关代码片段筛选自各路编程大神贡献的开源项目,源码版权归原作者所有,传播和使用请参考对应项目的License;未经允许,请勿转载。