เราจะมาดูวิธีหาความแตกต่างระหว่างตัวเลข X ตัวแรกและตัวสุดท้ายของตัวเลข N โดยให้ตัวเลขและ X เพื่อแก้ปัญหานี้ เราต้องหาความยาวของตัวเลข จากนั้นตัดตัวเลข x สุดท้ายโดยใช้ตัวดำเนินการโมดูลัส หลังจากนั้นให้ตัดตัวเลขทั้งหมดออกจากตัวเลข ยกเว้น x หลักแรก จากนั้นรับส่วนต่างและส่งคืนผลลัพธ์ ให้ตัวเลขคือ N =568424 X คือ 2 ดังนั้นสองหลักแรกคือ 56 และสองหลักสุดท้ายคือ 24 ส่วนต่างคือ (56 - 24) =32
อัลกอริทึม
diffFirstLastDigits(N, X)
begin p := 10^X last := N mod p len := length of the number N while len is not same as X, do N := N / 10 len := len -1 done first := len return |first - last| end
ตัวอย่าง
#include <iostream>
#include <cmath>
using namespace std;
int lengthCount(int n){
return floor(log10(n) + 1);
}
int diffFirstLastDigits(int n, int x) {
int first, last, p, len;
p = pow(10, x);
last = n % p;
len = lengthCount(n);
while(len != x){
n /= 10;
len--;
}
first = n;
return abs(first - last);
}
main() {
int n, x;
cout << "Enter number and number of digits from first and last: ";
cin >> n >> x;
cout << "Difference: " << diffFirstLastDigits(n,x);
} ผลลัพธ์
Enter number and number of digits from first and last: 568424 2 Difference: 32