Advertisement
Guest User

Untitled

a guest
Mar 19th, 2019
57
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
text 3.80 KB | None | 0 0
  1. #include <stdio.h>
  2.  
  3. #include <stdlib.h>
  4.  
  5.  
  6.  
  7. int mp = 0;
  8.  
  9.  
  10.  
  11.  
  12.  
  13. void max_profit(int events[][3], int used[], int n_events, int bd, int profit, int lta) {
  14.  
  15. int i;
  16.  
  17. int new_profit = profit;
  18.  
  19. int new_lta = lta;
  20.  
  21. for (i = 0; i < n_events; i++) {
  22.  
  23. if (used[i])
  24.  
  25. continue;
  26.  
  27. used[i] = 1;
  28.  
  29. if (lta + events[i][1] <= bd && lta + events[i][1] <= events[i][0]) {
  30.  
  31. new_lta = lta + events[i][1];
  32.  
  33. new_profit = profit + events[i][2];
  34.  
  35. mp = max(mp, new_profit);
  36.  
  37. max_profit(events, used, n_events, bd, new_profit, new_lta);
  38.  
  39. }
  40.  
  41. used[i] = 0;
  42.  
  43. }
  44.  
  45. }
  46.  
  47.  
  48.  
  49.  
  50.  
  51. void swap(int* a, int* b)
  52.  
  53. {
  54.  
  55. int t = *a;
  56.  
  57. *a = *b;
  58.  
  59. *b = t;
  60.  
  61. }
  62.  
  63.  
  64.  
  65. int min(int a , int b) {
  66.  
  67. if (a < b)
  68.  
  69. return a;
  70.  
  71. return b;
  72.  
  73. }
  74.  
  75.  
  76.  
  77. int max(int a, int b) {
  78.  
  79. if (a > b)
  80.  
  81. return a;
  82.  
  83. return b;
  84.  
  85. }
  86.  
  87.  
  88.  
  89. int partition (int arr[][3], int low, int high)
  90.  
  91. {
  92.  
  93. int pivot = arr[high][0]; // pivot
  94.  
  95. int i = (low - 1); // Index of smaller element
  96.  
  97.  
  98.  
  99. for (int j = low; j <= high- 1; j++)
  100.  
  101. {
  102.  
  103. // If current element is smaller than or
  104.  
  105. // equal to pivot
  106.  
  107. if (arr[j][0] <= pivot)
  108.  
  109. {
  110.  
  111. i++; // increment index of smaller element
  112.  
  113. swap(&arr[i][0], &arr[j][0]);
  114.  
  115. }
  116.  
  117. }
  118.  
  119. swap(&arr[i + 1][0], &arr[high][0]);
  120.  
  121. return (i + 1);
  122.  
  123. }
  124.  
  125.  
  126.  
  127. /* The main function that implements QuickSort
  128.  
  129. arr[] --> Array to be sorted,
  130.  
  131. low --> Starting index,
  132.  
  133. high --> Ending index */
  134.  
  135. void quickSort(int arr[][3], int low, int high)
  136.  
  137. {
  138.  
  139. if (low < high)
  140.  
  141. {
  142.  
  143. /* pi is partitioning index, arr[p] is now
  144.  
  145. at right place */
  146.  
  147. int pi = partition(arr, low, high);
  148.  
  149.  
  150.  
  151. // Separately sort elements before
  152.  
  153. // partition and after partition
  154.  
  155. quickSort(arr, low, pi - 1);
  156.  
  157. quickSort(arr, pi + 1, high);
  158.  
  159. }
  160.  
  161. }
  162.  
  163.  
  164.  
  165. int algo(int n_events, int events[][3], int aux[][2], int max_dealine)
  166.  
  167. {
  168.  
  169.  
  170.  
  171. int i, j, taux;
  172.  
  173.  
  174.  
  175. printf("%d\n", max_dealine);
  176.  
  177.  
  178.  
  179. for (j = 0; j <= n_events; j++)
  180.  
  181. {
  182.  
  183. aux[0][j] = 0;
  184.  
  185. }
  186.  
  187.  
  188.  
  189. for (i = 1; i <= max_dealine; i++)
  190.  
  191. {
  192.  
  193.  
  194.  
  195. aux[i][0] = 0;
  196.  
  197. }
  198.  
  199.  
  200.  
  201. for (i = 1; i <= n_events; i++)
  202.  
  203. {
  204.  
  205.  
  206.  
  207. for (j = 1; j <= max_dealine; j++)
  208.  
  209. {
  210.  
  211.  
  212.  
  213. taux = min(j, events[i][0]) - events[i][1];
  214.  
  215.  
  216.  
  217. if (taux <= 0)
  218.  
  219. {
  220.  
  221.  
  222.  
  223. aux[i][j] = aux[i - 1][j];
  224.  
  225. }
  226.  
  227. else
  228.  
  229. {
  230.  
  231.  
  232.  
  233. aux[i][j] = max(aux[i - 1][j], events[i][2] + aux[i - 1][taux]);
  234.  
  235. }
  236.  
  237. }
  238.  
  239. }
  240.  
  241. printf("%d\n", aux[n_events][max_dealine]);
  242.  
  243.  
  244.  
  245. //for (int i = 0; i < max_dealine; i++){
  246.  
  247. //for(j=0;i<n_events;j++){
  248.  
  249. //printf("%d\n", aux[i][j], aux[i][j]);
  250.  
  251. //}
  252.  
  253. //}
  254.  
  255.  
  256.  
  257.  
  258.  
  259.  
  260.  
  261. //max(T[i 􀀀 1; j ]; vi + T[i 􀀀 1; j 􀀀 wi ])
  262.  
  263.  
  264.  
  265. return 0;
  266.  
  267. }
  268.  
  269.  
  270.  
  271. int main(int argc, char const *argv[]) {
  272.  
  273. int i, n_events, bd = 0,maxi;
  274.  
  275.  
  276.  
  277.  
  278.  
  279. while (scanf("%d", &n_events) > 0) {
  280.  
  281. int events[n_events][3];
  282.  
  283. for (i = 0; i < n_events; i++)
  284.  
  285. scanf("%d %d %d", &events[i][0], &events[i][1], &events[i][2]);
  286.  
  287.  
  288.  
  289. quickSort(events, 0, n_events-1);
  290.  
  291. int max_dealine=events[n_events-1][0];
  292.  
  293. int aux[n_events][max_dealine];
  294.  
  295. //printf("saddsadsa\n");
  296.  
  297. maxi=algo(n_events,events,aux,max_dealine);
  298.  
  299. /*
  300.  
  301. int used[n_events];
  302.  
  303. for (i = 0; i < n_events; i++)
  304.  
  305. used[i] = 0;
  306.  
  307.  
  308.  
  309. for (i = 0; i < n_events; i++)
  310.  
  311. if (events[i][0] > bd)
  312.  
  313. bd = events[i][0];
  314.  
  315.  
  316.  
  317. max_profit(events, used, n_events, bd, 0, 0);
  318.  
  319.  
  320.  
  321. printf("%d\n", mp);
  322.  
  323. */
  324.  
  325. }
  326.  
  327. return 0;
  328.  
  329. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement