Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> C++

ค้นหาหมายเลขคอลัมน์ Excel จากชื่อคอลัมน์ใน C++


เรารู้ว่าหมายเลขคอลัมน์ excel เป็นตัวอักษร มันเริ่มต้นจาก A และหลังจาก Z มันจะเป็น AA, AB ถึง ZZ จากนั้นอีกครั้ง AAA, AAB ถึง ZZZ เป็นต้น ดังนั้นคอลัมน์ที่ 1 คือ A คอลัมน์ที่ 27 คือ Z ที่นี่เราจะดูวิธีรับตัวอักษรประจำคอลัมน์หากระบุจำนวนคอลัมน์ ดังนั้นหากหมายเลขคอลัมน์คือ 80 ก็จะเป็น CB

สมมุติว่าเรามีตัวเลข n และค่าของมันคือ 28 เราต้องเตือนความจำด้วย 26 ถ้าเศษเหลือเป็น 0 ตัวเลขก็คือ 26, 52 ไปเรื่อยๆ จากนั้นเราใส่ Z ลงในสตริงเอาต์พุต ค่าของ n จะกลายเป็น n/26 – 1 และถ้าเศษที่เหลือไม่ใช่ศูนย์ เราก็จำเป็นต้องใส่อักขระลงในสตริงตามนั้น และทำ n =n/26 ในที่สุด ด้านหลังของสตริงจะถูกพิมพ์

ตัวอย่าง

#include<iostream>
#include<algorithm>
using namespace std;
void showColumnLetters(int n) {
   string str = "";
   while (n) {
      int rem = n%26;
      if (rem==0) {
         str += 'Z';
         n = (n/26)-1;
      }
      else{
         str += (rem-1) + 'A';
         n = n/26;
      }
   }
   reverse(str.begin(), str.begin() + str.length());
   cout << str << endl;
}
int main() {
   int n = 700;
   cout << "Cell name of " << n << " is: ";
   showColumnLetters(700);
}

ผลลัพธ์

Cell name of 700 is: ZX