Khác nhau tổng 2 đường chéo (Diagonal Difference)

bài toán

cho ma trận hình vuông , tình sự khác tổng giá trị tuyệt đối của 2 đường chéo
ví dụ cho ma trận hình vuông như sau

1 2 3
4 5 6
9 8 9

giá trị đường chéo từ trái sang phải 1 + 5 + 9 = 15 giá trị từ phải sang trái 3 + 5 + 9 = 17 . giá trị tuyệt đối |15 - 17| = 2

Miêu tả chức năng
Hoàn thành chức năng sau DiagonalDifference tính giá trị tuyệt đối của 2 đường chéo. Parameter gồm ar: mảng các số tự nhiên

giá trị đầu vào
dòng đầu tiên là giá trị của dòng và cột của ma trận
dòng thứ 2 là giá trị các phần tử

điều kiện ràng buộc
-100 <= arr[i][j] <= 100

giá trị đầu vào

3
11 2 4
4   5 6
10 8 -12

giá trị đầu ra
15

giải thích
đường chéo thứ nhất
11
    5
      -12

tổng dường chéo thứ nhất 11 + 5 - 12 = 4

đường chéo thứ 2
          4
      5
10

tổng đường chéo 4 + 5 + 10 = 19
giá trị tuyệt đối |4 - 19| = 15

Luu ý |x| là giá tị tuyệt đối của x

php

<?php

/*
* Complete the 'diagonalDifference' function below.
*
* The function is expected to return an INTEGER.
* The function accepts 2D_INTEGER_ARRAY arr as parameter.
*/

function diagonalDifference($arr) {
// Write your code here
$arrDiag = count($arr);
$firstD = 0;
$secondD = 0;
$i =0;
for($j = 0; $j < $arrDiag; $j++) {
$firstD += $arr[$i++][$j];
$secondD += $arr[$arrDiag - $i][$j];
}
return abs($firstD - $secondD);
}

$fptr = fopen(getenv("OUTPUT_PATH"), "w");

$n = intval(trim(fgets(STDIN)));

$arr = array();

for ($i = 0; $i < $n; $i++) {
$arr_temp = rtrim(fgets(STDIN));

$arr[] = array_map('intval', preg_split('/ /', $arr_temp, -1, PREG_SPLIT_NO_EMPTY));
}

$result = diagonalDifference($arr);

fwrite($fptr, $result . "\n");

fclose($fptr);

Comments

Popular posts from this blog

Intro to Tutorial Challenges

Mini-Max Sum