Lay2sotonhatcongvaodaylaivao
Level 3 Partition 1 This time, Samsung Electronics, in a new building was built on the Umyeon Dong. Wireless division also was assigned to the spacious. The total space for Wireless division is fixed and the space for each group is fixed. Now we should assign partitions for each group. The time for assigning partition is proportional to size of space. For example, if the size of space is 1000, it spends time of 1000 to partition it (It spends same time if we partition it as 300+700 or 500+500.) The total time depends on the order of partitioning. For example, in case the size of total space is 800, and each size for groups is 100, 200, and 500. If partitioning 100+700 first, partitioning 200+500 later, then the total time is 800+700=1500 But, if partitioning 500+300 first, partitioning 100+200 later, then the total time is 800+300=1100 Write program to print the minimum time to partition for all groups. [Input] There can be more than one test case in the input. The first line has T, the number of test cases. Then the totally T test cases are provided in the following lines. In each test case, the first line has an integer N(1 ≤ N ≤ 1000); the number of group. The next line enumerates N integers each separated by a blank; each integer means the size of space(S) for each group. (10≤S≤5000) [Output] For each test case, you should print your answer in two line. [Sample] Input 2 3 500 100 200 4 30 40 10 20 Output Case #1 1100 Case #2 190 Case #1 1100 Case #2 10220 Case #3 28316 Case #4 42035 Case #5 35015 Case #6 10916700 Case #7 28316 Case #8 42035 Case #9 35015 Case #10 10916700 10 3 500 100 200 10 10 10 20 40 80 160 320 640 1280 2560 13 13 21 34 55 89 144 233 377 610 987 1597 2584 4181 26 816 149 278 425 1270 222 201 609 696 15 74 402 240 674 750 192 10 598 632 905 275 103 236 15 197 10 100 78 49 76 74 83 86 89 94 75 99 25 65 39 50 71 91 15 82 92 52 38 73 96 33 27 10 62 62 16 16 79 49 14 58 50 76 54 71 24 93 15 50 44 13 49 58 83 39 50 27 82 81 91 54 81 70 95 51 33 87 22 11 77 62 21 41 72 39 98 37 71 28 59 46 49 18 34 84 78 10 67 13 20 79 11 32 90 33 18 71 46 11 98 96 56 12 12 38 46 77 500 10 20 30 40 50 60 70 80 90 100 110 120 130 140 150 160 170 180 190 200 210 220 230 240 250 260 270 280 290 300 310 320 330 340 350 360 370 380 390 400 410 420 430 440 450 460 470 480 490 500 510 520 530 540 550 560 570 580 590 600 610 620 630 640 650 660 670 680 690 700 710 720 730 740 750 760 770 780 790 800 810 820 830 840 850 860 870 880 890 900 910 920 930 940 950 960 970 980 990 1000 1010 1020 1030 1040 1050 1060 1070 1080 1090 1100 1110 1120 1130 1140 1150 1160 1170 1180 1190 1200 1210 1220 1230 1240 1250 1260 1270 1280 1290 1300 1310 1320 1330 1340 1350 1360 1370 1380 1390 1400 1410 1420 1430 1440 1450 1460 1470 1480 1490 1500 1510 1520 1530 1540 1550 1560 1570 1580 1590 1600 1610 1620 1630 1640 1650 1660 1670 1680 1690 1700 1710 1720 1730 1740 1750 1760 1770 1780 1790 1800 1810 1820 1830 1840 1850 1860 1870 1880 1890 1900 1910 1920 1930 1940 1950 1960 1970 1980 1990 2000 2010 2020 2030 2040 2050 2060 2070 2080 2090 2100 2110 2120 2130 2140 2150 2160 2170 2180 2190 2200 2210 2220 2230 2240 2250 2260 2270 2280 2290 2300 2310 2320 2330 2340 2350 2360 2370 2380 2390 2400 2410 2420 2430 2440 2450 2460 2470 2480 2490 2500 2510 2520 2530 2540 2550 2560 2570 2580 2590 2600 2610 2620 2630 2640 2650 2660 2670 2680 2690 2700 2710 2720 2730 2740 2750 2760 2770 2780 2790 2800 2810 2820 2830 2840 2850 2860 2870 2880 2890 2900 2910 2920 2930 2940 2950 2960 2970 2980 2990 3000 3010 3020 3030 3040 3050 3060 3070 3080 3090 3100 3110 3120 3130 3140 3150 3160 3170 3180 3190 3200 3210 3220 3230 3240 3250 3260 3270 3280 3290 3300 3310 3320 3330 3340 3350 3360 3370 3380 3390 3400 3410 3420 3430 3440 3450 3460 3470 3480 3490 3500 3510 3520 3530 3540 3550 3560 3570 3580 3590 3600 3610 3620 3630 3640 3650 3660 3670 3680 3690 3700 3710 3720 3730 3740 3750 3760 3770 3780 3790 3800 3810 3820 3830 3840 3850 3860 3870 3880 3890 3900 3910 3920 3930 3940 3950 3960 3970 3980 3990 4000 4010 4020 4030 4040 4050 4060 4070 4080 4090 4100 4110 4120 4130 4140 4150 4160 4170 4180 4190 4200 4210 4220 4230 4240 4250 4260 4270 4280 4290 4300 4310 4320 4330 4340 4350 4360 4370 4380 4390 4400 4410 4420 4430 4440 4450 4460 4470 4480 4490 4500 4510 4520 4530 4540 4550 4560 4570 4580 4590 4600 4610 4620 4630 4640 4650 4660 4670 4680 4690 4700 4710 4720 4730 4740 4750 4760 4770 4780 4790 4800 4810 4820 4830 4840 4850 4860 4870 4880 4890 4900 4910 4920 4930 4940 4950 4960 4970 4980 4990 5000 13 13 21 34 55 89 144 233 377 610 987 1597 2584 4181 26 816 149 278 425 1270 222 201 609 696 15 74 402 240 674 750 192 10 598 632 905 275 103 236 15 197 10 100 78 49 76 74 83 86 89 94 75 99 25 65 39 50 71 91 15 82 92 52 38 73 96 33 27 10 62 62 16 16 79 49 14 58 50 76 54 71 24 93 15 50 44 13 49 58 83 39 50 27 82 81 91 54 81 70 95 51 33 87 22 11 77 62 21 41 72 39 98 37 71 28 59 46 49 18 34 84 78 10 67 13 20 79 11 32 90 33 18 71 46 11 98 96 56 12 12 38 46 77 500 10 20 30 40 50 60 70 80 90 100 110 120 130 140 150 160 170 180 190 200 210 220 230 240 250 260 270 280 290 300 310 320 330 340 350 360 370 380 390 400 410 420 430 440 450 460 470 480 490 500 510 520 530 540 550 560 570 580 590 600 610 620 630 640 650 660 670 680 690 700 710 720 730 740 750 760 770 780 790 800 810 820 830 840 850 860 870 880 890 900 910 920 930 940 950 960 970 980 990 1000 1010 1020 1030 1040 1050 1060 1070 1080 1090 1100 1110 1120 1130 1140 1150 1160 1170 1180 1190 1200 1210 1220 1230 1240 1250 1260 1270 1280 1290 1300 1310 1320 1330 1340 1350 1360 1370 1380 1390 1400 1410 1420 1430 1440 1450 1460 1470 1480 1490 1500 1510 1520 1530 1540 1550 1560 1570 1580 1590 1600 1610 1620 1630 1640 1650 1660 1670 1680 1690 1700 1710 1720 1730 1740 1750 1760 1770 1780 1790 1800 1810 1820 1830 1840 1850 1860 1870 1880 1890 1900 1910 1920 1930 1940 1950 1960 1970 1980 1990 2000 2010 2020 2030 2040 2050 2060 2070 2080 2090 2100 2110 2120 2130 2140 2150 2160 2170 2180 2190 2200 2210 2220 2230 2240 2250 2260 2270 2280 2290 2300 2310 2320 2330 2340 2350 2360 2370 2380 2390 2400 2410 2420 2430 2440 2450 2460 2470 2480 2490 2500 2510 2520 2530 2540 2550 2560 2570 2580 2590 2600 2610 2620 2630 2640 2650 2660 2670 2680 2690 2700 2710 2720 2730 2740 2750 2760 2770 2780 2790 2800 2810 2820 2830 2840 2850 2860 2870 2880 2890 2900 2910 2920 2930 2940 2950 2960 2970 2980 2990 3000 3010 3020 3030 3040 3050 3060 3070 3080 3090 3100 3110 3120 3130 3140 3150 3160 3170 3180 3190 3200 3210 3220 3230 3240 3250 3260 3270 3280 3290 3300 3310 3320 3330 3340 3350 3360 3370 3380 3390 3400 3410 3420 3430 3440 3450 3460 3470 3480 3490 3500 3510 3520 3530 3540 3550 3560 3570 3580 3590 3600 3610 3620 3630 3640 3650 3660 3670 3680 3690 3700 3710 3720 3730 3740 3750 3760 3770 3780 3790 3800 3810 3820 3830 3840 3850 3860 3870 3880 3890 3900 3910 3920 3930 3940 3950 3960 3970 3980 3990 4000 4010 4020 4030 4040 4050 4060 4070 4080 4090 4100 4110 4120 4130 4140 4150 4160 4170 4180 4190 4200 4210 4220 4230 4240 4250 4260 4270 4280 4290 4300 4310 4320 4330 4340 4350 4360 4370 4380 4390 4400 4410 4420 4430 4440 4450 4460 4470 4480 4490 4500 4510 4520 4530 4540 4550 4560 4570 4580 4590 4600 4610 4620 4630 4640 4650 4660 4670 4680 4690 4700 4710 4720 4730 4740 4750 4760 4770 4780 4790 4800 4810 4820 4830 4840 4850 4860 4870 4880 4890 4900 4910 4920 4930 4940 4950 4960 4970 4980 4990 5000 #include <iostream> using namespace std; int T, n; long result; int arr[1001], L[501], R[501]; void merge(int a[], int l, int m, int r){ int n1 = m - l + 1, n2 = r - m; for(int i = 0; i < n1; i++) L[i] = a[i+l]; for(int j = 0; j < n2; j++) R[j] = a[j+m+1]; int i = 0, j = 0, k = l; while(i < n1 && j < n2){ if(L[i] < R[j]) a[k++] = L[i++]; else a[k++] = R[j++]; } while(i < n1) a[k++] = L[i++]; while(j < n2) a[k++] = R[j++]; } void mergeSort(int a[], int l, int r){ if(l < r){ int m = l + (r-l)/2; mergeSort(a, l, m); mergeSort(a, m+1, r); merge(a, l, m, r); } } int main(){ freopen("input.txt", "r", stdin); cin >> T; for(int tc = 1; tc <= T; tc++){ // Input cin >> n; for(int i = 0; i < n; i++){ cin >> arr[i]; } // Initial result = 0; // Solve Problem for(int i = 0; i < n - 1; i++){ mergeSort(arr, i, n-1); result += (arr[i] + arr[i+1]); arr[i+1] += arr[i]; } // Output cout << "Case #" << tc << endl << result << endl; } return 0; }
Leave a Comment