Advertisement
avr39-ripe

bbr192FPointersLecture

Apr 1st, 2020
228
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 2.56 KB | None | 0 0
  1. #include <iostream>
  2.  
  3.  
  4. void fun() { std::cout << "Fun\n"; };
  5. void fun1() { std::cout << "Fun1\n"; };
  6.  
  7. void funVal(int val) { std::cout << "FunVal with val = " << val << '\n'; };
  8. void funVal1(int val) { std::cout << "FunVal1 with val = " << val << '\n'; };
  9.  
  10. int min(int a, int b) { return a < b ? a : b; };
  11. int max(int a, int b) { return a > b ? a : b; };
  12.  
  13. char fun(float* fPtr, int size);
  14.  
  15. void zero() { std::cout << "Value is zero\n"; };
  16. void above() { std::cout << "Value is above zero\n"; };
  17. void beyond() { std::cout << "Value is beyond zero\n"; };
  18.  
  19. bool sortUp(int a, int b) { return a < b; };
  20. bool sortDown(int a, int b) { return a > b; };
  21. bool sortOdd(int a, int b) { return (a%2 == 0) and (b % 2 !=0); };
  22. bool sortEven(int a, int b) { return (a % 2 != 0) and (b % 2 == 0); };
  23.  
  24. void printArrRow(int* arr, int arrSize)
  25. {
  26.     for (int i = 0; i < arrSize; i++) { std::cout << arr[i] << ' '; }; std::cout << '\n';
  27. }
  28.  
  29. void printArrRowTab(int* arr, int arrSize)
  30. {
  31.     for (int i = 0; i < arrSize; i++) { std::cout << arr[i] << '\t'; }; std::cout << '\n';
  32. }
  33.  
  34. void printArrCol(int* arr, int arrSize)
  35. {
  36.     for (int i = 0; i < arrSize; i++) { std::cout << arr[i] << '\n'; }; std::cout << '\n';
  37. }
  38.  
  39.  
  40. void sortBuble(int* arr, int arrSize, bool(*sortCriteria)(int, int)=nullptr, void(*print)(int*, int)=nullptr)
  41. {
  42.     if (print) { print(arr, arrSize); };
  43.     for (int head{ 0 }; head < arrSize; ++head)
  44.     {
  45.         for (int tail{ arrSize - 1 }; tail > head; --tail)
  46.         {
  47.             if ((sortCriteria and sortCriteria(arr[tail],arr[head])) or (!sortCriteria and (arr[tail] < arr[head])))
  48.             {
  49.                 int tmp = arr[head];
  50.                 arr[head] = arr[tail];
  51.                 arr[tail] = tmp;
  52.             }
  53.         }
  54.     }
  55.     if (print) { print(arr, arrSize); };
  56. }
  57.  
  58. void printArr(int* arr, int arrSize)
  59. {
  60.     for (int i = 0; i < arrSize; i++) { std::cout << arr[i] << ' '; }; std::cout << '\n';
  61. }
  62.  
  63. int main()
  64. {
  65.     int arrSize{ 15 };
  66.     int* arr{ new int[arrSize] { 6,1,4,2,8,9,11,26,2,7,8,11,2,2,3 } };
  67.     //printArr(arr, arrSize);
  68.     sortBuble(arr, arrSize,nullptr,printArrRow);
  69.     //printArr(arr, arrSize);
  70.  
  71.     //void (*assetValue)() { nullptr };
  72.  
  73.     //int value{ 0 };
  74.     //std::cout << "Enter number\n";
  75.     //std::cin >> value;
  76.  
  77.     ////if (value == 0) { assetValue = zero; };
  78.     //if (value > 0) { assetValue = above; };
  79.     //if (value < 0) { assetValue = beyond; };
  80.  
  81.     //if (assetValue) { assetValue(); }
  82.     //else { std::cout << "assetValue is nullptr!\n"; };
  83.  
  84.     //char(*funPointer)(float*, int) {nullptr};
  85.     //void (*funPtr)() { fun };
  86.     //void (*funValPtr)(int) { funVal };
  87.     //int(*minMaxPtr)(int, int) { min };
  88.  
  89.     //funPtr();
  90.     //funValPtr(33);
  91. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement