Trang chủ Tin Học Lớp 8 Cho số nguyên dương X có k chữ số, đổi...

Cho số nguyên dương X có k chữ số, đổi tùy ý vị trí các chữ số của X ta thu được số Y. Yêu cầu: Hãy tìm số Y nhỏ nhất. Dữ liệu vào: Cho trong file văn bản DOIS

Câu hỏi :

Cho số nguyên dương X có k chữ số, đổi tùy ý vị trí các chữ số của X ta thu được số Y. Yêu cầu: Hãy tìm số Y nhỏ nhất. Dữ liệu vào: Cho trong file văn bản DOISO.INP có cấu trúc như sau: - Dòng 1: Ghi số nguyên dương k. (0<k<109) - Dòng 2: Ghi số X. Dữ liệu ra: Ghi ra file văn bản DOISO.OUT theo cấu trúc sau: - Dòng 1: Ghi số Y tìm được. (Không cần ghi các số không đứng đầu)

Lời giải 1 :

Mình viết code C++ nhé:

#include <algorithm>

#include <fstream>
#include <string>
using namespace std;
int main()
{

 //Chúng ta mở các file:
 ifstream fin("DOISO.INP");
 ofstream fout("DOISO.OUT");

 //Vì số X quá lớn nên chúng ta phải dùng dạng xâu:
 string X;
 int k;

 //Nhập vào dữ liệu:
 fin >> k;
 fin >> X;

 //Dùng hàm sort() có sẵn trong thư viện, để đưa các chữ số nhỏ hơn đứng trước các chữ số lớn hơn:
 sort(X.begin(), X.end());

 //Loại bỏ các số 0 thừa ở đầu:
 while ((X.length() > 1) && (X[0] == '0')) X.erase(0, 1);

 //Trả về kết quả:
 fout << X;

 //Kết thúc:

 return 0;
}

//Chúng ta không cần đóng file hay làm gì khác vì chương trình sẽ tự động dọn dẹp khi kết thúc.

Thảo luận

Bạn có biết?

Tin học, tiếng Anh: informatics, tiếng Pháp: informatique, là một ngành khoa học chuyên nghiên cứu quá trình tự động hóa việc tổ chức, lưu trữ, xử lý và truyền dẫn thông tin của một hệ thống máy tính cụ thể hoặc trừu tượng (ảo). Với cách hiểu hiện nay, tin học bao hàm tất cả các nghiên cứu và kỹ thuật có liên quan đến việc mô phỏng, biến đổi và tái tạo thông tin.

Nguồn : Wikipedia - Bách khoa toàn thư

Tâm sự 8

Lớp 8 - Năm thứ ba ở cấp trung học cơ sở, học tập bắt đầu nặng dần, sang năm lại là năm cuối cấp áp lực lớn dần nhưng các em vẫn phải chú ý sức khỏe nhé!

Nguồn : ADMIN :))

Copyright © 2021 HOCTAP247