[Thuật toán đồ thị / code C++] Kiểm tra tính liên thông của đồ thị G

[Thuật toán đồ thị / code C++] Kiểm tra tính liên thông của đồ thị G

Mô tả bài toán: 
  Cho đồ thị vô hướng G = (V,E) hãy kiểm tra tính liên thông của đồ thị G.

Ý tưởng thuật toán:
  Bước 1: xuất phát từ một đỉnh bất kỳ của đồ thị. Ta đánh dấu đỉnh xuất phát và chuyển sang Bước 2.
  Bước 2: từ một đỉnh i đã đánh dấu, ta đánh dấu đỉnh j nếu A[i,j] = 1 và j chưa được đánh dấu và chuyển sang Bước 3.
  Bước 3: thực hiện Bước 2 cho đến khi không còn thực hiện được nữa chuyển sang Bước 4.
  Bước 4: kiểm tra nếu số đỉnh đánh dấu nhỏ hơn n (hay tồn tại ít nhất một đỉnh chưa được đánh dấu) đồ thị sẽ không liên thông và ngược lại đồ thị liên thông.

Mô tả dữ liệu đầu vào và đầu ra của bài toán:
Dữ liệu vào: cho trong tập tin Input.txt
 - Dòng đầu ghi số n là số đỉnh của một đồ thị (0<n<100).
 - Dòng i+1 (1 < i < n ) chứa n số A[i,1],A[i,2]…A[i,n] mỗi số cách nhau bởi một khoảng trắng.
Dữ liệu ra: thông báo kết quả ra màn hình ”DO THI LIEN THONG” hay “ DO THI KHONG LIEN THONG”.



Ví dụ:

[Cài đặt: Code Turbo C++]

#include <stdio.h>
#include <conio.h>
#include <iostream.h>


//doc du lieu tu tap tin
void Doc_File(int **A,int &n) {
  FILE*f = fopen("Input.txt","rb");
  fscanf(f,"%d",&n);
  *A = new int [n];
  cout<<"Ma Tran Lien Ket Cua Do Thi";
  for(int i =0;i<n;i++) {
     A[i] = new int [n];
     cout<<endl;
     for(int j =0;j<n;j++) {
        fscanf(f,"%d",&A[i][j]);
        cout<<" "<<A[i][j];
     }
  }
fclose(f);
}

//kiem tra tinh lien thong neu lien thong tra ve gia tri 1 nguoc lai tra ve gia tri 0

char Lien_Thong(int **A,int n) {
  char*DanhDau = new char [n];
  char ThanhCong;
  int Dem=0;
  for(int i = 0; i<n; i++) //Khoi tao moi dinh chua danh dau
     DanhDau[i] = 0;
  DanhDau[0] = 1; //danh dau dinh dau
  Dem++; //dem so dinh duoc danh dau
  do {
     ThanhCong =1; //khong con kha nang loang
      for(i = 0; i<n; i++)
             if(DanhDau[i]==1)
            {
                   for(int j = 0; j<n; j++)
                        if (DanhDau[j] == 0 && A[i][j] > 0)
                        {
                           DanhDau[j] = 1;
                           ThanhCong = 0; //con kha nang loang
                           Dem++;
                           if(Dem == n)
                               return 1;
                         }
             }
   }while (ThanhCong == 0); //lap lai cho den khi khong con kha nang loan
   return 0;
}

//chuong trinh chinh
void main()
{
    clrscr();
    int **A,n;
    Doc_File(A,n);
    if (Lien_Thong(A,n)==1)
       cout<<"\nDO THI LIEN THONG";
    else cout<<"\nDO THI KHONG LIEN THONG";
       delete *A;
    
   getch();
}


>> Giáo Trình C++ Và Lập Trình Hướng Đối Tượng

Có thể bạn quan tâm: Kiếm tiền online với Honeygain

Chúc các bạn thành công!

[Tự học lập trình Java] Bài 2: Các kiểu dữ liệu và toán tử trong Java

1. Kiểu dữ liệu trong Java

Một số tài liệu và khoá học bổ ích dành cho bạn: 

# Tài liệu: Lập trình hướng đối tượng JAVA core dành cho người mới bắt đầu học lập trình [Click để xem]

# Khoá học online: Lập trình Java trong 4 tuần [Click để xem]


- Các kiểu dữ liệu nguyên thủy (primitive)

Kiểu dữ liệu
Độ dài theo số bit
Phạm vi biểu diễn giá trị
Mô tả
byte
8
-128 đến 127
Số liệu kiểu byte là một loại điển hình dùng để lưu trữ một giá tri bằng một byte. Chúng được sử dụng rộng rãi khi xử lý một file văn bản
char
16
‘\u0000’ to ’u\ffff ’
Kiểu Char sử dụng để lưu tên hoặc các dữ liệu ký tự .Ví dụ tên ngườI lao động
boolean
1
“True” hoặc “False”
Dữ liệu boolean dùng để lưu các giá trị “Đúng” hoặc “sai” Ví dụ : Người lao đông có đáp ứng được yêu cầu của công ty hay không ?
short
16
-32768 đến 32767
Kiểu short dùng để lưu các số có giá trị nhỏ dưới 32767.Ví dụ số lượng người lao động.
int
32
-2,147,483,648 đến +2,147,483,648
Kiểu int dùng để lưu một số có giá trị lớn đến 2,147,483,648.Ví dụ tổng lương mà công ty phải trả cho nhân viên.
long
64
-9,223,372,036’854,775,808 đến +9,223,372,036’854,775,808
Kiểu long được sử dụng để lưu một số cố giá trị rất lớn đến 9,223,372,036’854,775,808 .Ví dụ dân số của một nước
float
32
-3.40292347E+38 đến +3.40292347E+38
Kiểu float dùng để lưu các số thập phân đến 3.40292347E+38 Ví dụ : giá thành sản phẩm
double
64
-1,79769313486231570E+308 đến +1,79769313486231570E+308
Kiểu double dùng để lưu các số thập phân có giá trị lớn đến
1,79769313486231570E+308 Ví dụ giá trị tín dụng của ngân hàng nhà nước.

- Kiểu dữ liệu tham chiếu (reference)

Kiểu dữ liệu
Mô tả
Mảng (Array)
Tập hợp các dữ liệu cùng kiểu. Ví dụ : tên sinh viên
Lớp (Class)
Tập hợp các biến và các phương thức.Ví dụ : lớp “Sinhviên” chứa toàn bộ các chi tiết của  một sinh viên và các phương thức thực thi trên các chi tiết đó.
Giao diện (Interface)
Là một lớp trừu tượng được tạo ra cho phép cài đặt đa thừa kế trong Java.

2. Ép kiểu (Type casting)

Có thể bạn sẽ gặp tình huống khi cộng một biến có dạng integer với một biến có dạng float. Để xử lý tình huống này, Java sử dụng tính năng ép kiểu (type casting) của các phần mềm trước đó C, C++. Lúc này một kiểu dữ liệu sẽ chuyển đổi sang kiểu khác. Khi sử dụng tính chất này, bạn cần thận trọng vì khi điều chỉnh dữ liệu có thể bị sai giá trị.

Đoạn mã sau đây thực hiện phép cộng một giá trị dấu phẩy động (float) với một giá trị nguyên (integer).

     float c=34.896751f; int b = (int)c +10;

Đầu tiên giá trị dấu phảy động c được đổi thành giá trị nguyên 34. Sau đó nó được cộng với 10 và kết quả là giá trị 44 được lưu vào b.

Sự nới rộng (widening) – quá trình làm tròn số theo hướng nới rộng không làm mất thông tin về độ lớn của mỗi giá trị.Biến đổi theo hướng nới rộng chuyển một giá trị sang một dạng khác có độ rộng phù hợp hơn so với nguyên bản. Biến đổi theo hướng lại thu nhỏ lại (narrowwing) làm mất thông tin về độ lớn của giá trị được chuyển đổi. Chúng không được thực hiện khi thực hiện phép gán. Ở ví dụ trên giá trị thập phân sau dấu phảy sẽ bị mất.

3. Các biến
Các ứng dụng sử dụng các biến để lưu trữ các dữ liệu cần thiết hoặc các dữ liệu được tạo ra trong quá trình thực thi chương trình. Các biến được xác định bởi một tên biến và có một phạm vi tác động. Phạm vi tác động của biến được xác định một cách rõ ràng trong chương trình. Mỗi biến được khai báo trong một khối chương trình chỉ có tác động trong phạm vi khối đó, không có ý nghĩa và không được phép truy nhập từ bên ngoài khối.

Việc khai báo một biến bao gồm 3 thành phần: kiểu biến, tên của nó và giá trị ban đầu được gán cho biến (không bắt buộc). Để khai báo nhiều biến ta sử dụng dấu phẩy để phân cách các biến, Khi khai báo biến, luôn nhớ rằng Java phân biệt chữ thường và chữ in hoa (case -sensitive).

Cú pháp:
   Datatype indentifier [=value] [, indentifier[=value]… ];

Ví dụ: Để khai báo một biến nguyên (int) có tên là counter dùng để lưu giá trị ban đầu là 1, ta có thể thực hiện phát biểu sau đây:

     int counter = 1;

Java có những yêu cầu hạn chế đặt tên biến mà bạn có thể gán giá trị vào. Những hạn chế này cũng giống các hạn chế khi đặt tên cho các định danh mà ta đã thảo luận ở các phần trước của chương này.

4. Hằng số
Hằng số là những giá trị không thay đổi trong quá trình xử lý tính toán.

Trong Java hằng được khai báo bằng từ khóa final

Ví dụ: final float PI=3.14f;

5. Toán tử (Operation)
Một chương trình thực tế bao hàm việc tạo ra các biến. Các toán tử kết hợp các giá trị đơn hoặc các biểu thức con thành những biểu thức mới, phức tạp hơn và có thể trả về giá trị. Điều này liên quan đến việc thực hiện các phép toán logic, số học, quan hệ và so sánh trên các biểu thức.

a. Các toán tử số học

Các toán hạng của các toán tử số học phải ở dạng số. Các toán hạng kiểu boolean không sử dụng được, song các toán hạng ký tự cho phép sử dụng loại toán tử này. Một vài kiểu toán tử được liệt kê trong bảng dưới đây.

Toán tử
Mô tả
+
Cộng.Trả về giá trị tổng hai toán hạng
Ví dụ: 5+3  trả về kết quả là 8
-
Trừ
Trả về giá trị khác nhau giữa hai toán hạng hoặc giá trị phủ định của toán hạng.
Ví dụ: 5-3 kết quả là 2 và –10 trả về giá trị âm của 10
*
Nhân
Trả về giá trị là tích hai toán hạng.
Ví dụ: 5*3 kết quả là 15
/
Chia
Trả về giá trị là thương của phép chia
Ví dụ: 6/3 kết quả là 2
%
Phép lấy modulo
Giá trị trả về là phần dư của phép chia
Ví dụ: 10%3  giá trị trả về là 1
++
Tăng dần
Tăng giá trị của biến lên 1. Ví dụ a++ tương đương với a= a+1
--
Giảm dần
Giảm giá trị của biến 1 đơn vị. Ví dụ a-- tương đương với a=a-1
+=
Cộng và gán giá trị
Cộng các giá trị của toán hạng bên trái vào toán hạng bên phải và gán giá trị trả về vào toán hạng bên trái.
Ví dụ: c+=a tương đương c=c+a
-=
Trừ và gán giá trị
Trừ các giá trị của toán hạng bên trái vào toán toán hạng bên phải và gán giá trị trả về vào toán hạng bên trái.
Ví dụ: c-= a tương đương vớI c=c-a
*=
Nhân và gán
Nhân các giá trị của toán hạng bên trái với toán toán hạng bên phải và gán giá trị trả về vào toán hạng bên trái.
Ví dụ: c *= a  tương đương với c=c*a
/=
Chia và gán
Chia giá trị của toán hạng bên trái cho toán toán hạng bên phải và gán giá trị trả về vào toán hạng bên trái.
Ví dụ: c /= a  tương đương với c=c/a
%=
Lấy  số dư và gán
Chia giá trị của toán hạng bên trái cho toán toán hạng bên phải và gán giá trị số dư vào toán hạng bên trái.
Ví dụ: c%=a tương đương với c=c%a


Ví dụ: 


Chương trình sau mô tả việc sử dụng toán tử số học

class ArithmeticOp {
 public static void main(String args[]){
  int p=5,q=12,r=20,s;
  s=p+q;
  System.out.println(“p+q is ”+s);
  s=p%q;
  System.out.println(“p%q is ”+s);
  s*=r;
  System.out.println(“s*=r is ”+s);
  System.out.println(“Value of p before operation is ”+p);
  p++;
  System.out.println(“Value of p after operation is ”+p);
  double x=25.75,y=14.25,z;
  z=x-y;
  System .out.println(“x-y is ” +z);
  z-=2.50;
  System.out.println(“z-=2.50 is “+z);
  System.out.println(“Value of z before operation is”+z);
  z--;
  System.out.println(“Value of z after operation is”+z);
  z=x/y;
  System .out.println(“x/y is” +z);
 }
}

Kết quả:

p+q is 17
p%q is 5
s*=r is 100
Value of p before operation is 9.0
Value of z after operation is 8.0
x/y is 1.8070175438596429

b. Toán tử Bit
Các toán tử dang Bit cho phép ta thao tác trên từng Bit riêng biệt trong các kiểu dữ liệu nguyên thuỷ. Toán tử Bit dựa trên cơ sở đại số Boolean. Nó thực hiện phép tính trên hai bit có vị trí tương ứng trên hai toán hạng để tạo ra một kết qủa mới. Một vài dạng toán tử kiểu này được liệt kê dưới đây

Toán tử
Mô tả
~
 Phủ định bit (NOT)
Trả về giá trị âm của một số. Ví dụ a=10 thì ~a=-10
&
Toán tử AND
Trả về giá trị là 1 nếu các toán hạng là 1 và 0 trong các trường hợp khác. Ví dụ nếu a=1và b=0 thì a&b trả về giá trị 0
|
Toán tử OR
Trả về giá trị là 1 nếu một trong các toán hạng là 1 và 0 trong các trường hợp khác. Ví dụ nếu a=1và b=0 thì a | b trả về giá trị 1
^
Exclusive OR
Trả về giá trị là 1 nếu chỉ một trong các toán hạng là 1 và trả về 0 trong các trường hợp khác. Ví dụ nếu a=1và b=1 thì a^b trả về giá trị 0
>> 
Dịch sang phải
Chuyển toàn bộ các bít cuả một số sang phải một vị trí, giữ nguyên dấu của số âm. Toán hạng bên trái là số bị dịch còn số bên phải chỉ số vị trí mà các bít cần dịch.
Ví dụ x=31 tức là 00011111 vậy x>>2 sẽ là 00000111.
<< 
Dịch sang trái
Chuyển toàn bộ các bít cuả một số sang trái một vị trí, giữ nguyên dấu cuả số âm. Toán hạng bên trái là số bị dịch còn số bên phải chỉ số vị trí mà các bít cần dịch.


c. Các toán tử quan hệ
Các toán tử quan hệ kiểm tra mối quan hệ giữa hai toán hạng. Kết quả của một biểu thức có dùng các toán tử quan hệ là những giá trị Boolean (logic “đúng” hoặc “sai”). Các toán tử quan hệ được sử dụng trong các cấu trúc điều khiển.
Toán tử
Mô tả
= =
So sánh bằng
Toán tử này kiểm tra sự tương đương của hai toán hạng
Ví dụ if (a= =b) trả về giá tri “True” nếu giá trị của a và b như nhau
!=
So sánh khác
Kiểm tra sự khác nhau của hai toán hạng
Ví dụ if (a!=b)  Trả về giá trị “true” nếu a khác b
>
Lớn hơn
Kiểm tra giá trị của toán hạng bên phải lớn hơn toán hạng bên trái hay không
Ví du  if(a>b) . Trả về giá trị “true” nếu a lớn hơn b,ngựơc lai (nhỏ hơn hoặc bằng ), trả về ‘False’
< 
Nhỏ hơn
Kiểm tra giá trị của toán hạng bên phải có nhỏ hơn toán hạng bên trái hay không
Ví du  if(a<b) . Trả về giá trị “true” nếu a  nhỏ hơn b , ngựơc lại (lớn hơn hoặc bằng trả về ‘False’
>=
Lớn hơn hoặc bằng
Kiểm tra giá trị của toán hạng bên phải có lớn hơn hoặc bằng toán hạng bên trái hay không
Ví du  if(a>=b) . Trả về giá trị “true” nếu a lớn hơn hoặc  bằng b , ngựơc lại (nhỏ hơn trả về ‘False’
<=
Nhỏ hơn hoặc bằng
Kiểm tra giá trị của toán hạng bên phải có nhỏ hơn hoặc bằng toán hạng bên trái hay không
Ví du  if(a<=b) . Trả về giá trị “true” nếu a nhỏ hơn hoặc  bằng b , ngựơc lại (lớn hơn trả về ‘false’)


Ví dụ: 
Đoạn chương trình sau đây mô tả việc sử dụng các toán tử quan hệ

class RelationalOp {
 public static void main (String args[]){
  float a= 10.0f;
  double b=10.0;
  if (a== b)
    System.out.println(a and b are equal”);
  else
    System.out.println(“a and b are not equal”);
 }
}

Kết quả: 
a and b are not equal

Trong chương trình trên cả a và b là những số có dấu phẩy động, dạng dữ liệu có khác nhau, a là kiểu float còn b là kiểu double. Tuy vậy chúng không phải là cùng một kiểu. Bởi vậy khi kiểm tra giá trị của các toán hạng, kiểu dữ liệu cần phải được kiểm tra.

d. Các toán tử logic
Các toán tử logic làm việc với các toán hạng Boolean. Một vài toán tử kiểu này được chỉ ra dưới đây

Toán tử
Mô tả
&&
Và (AND)
Trả về một giá trị “Đúng” (True) nếu chỉ khi cả hai toán tử có giá trị “True”
Ví dụ: if (sciencemarks>90) && (mathmarks>75) thì gán “Y” cho biến “được nhận học bổng”
||
Hoặc (OR)
Trả về giá trị “True” nếu một giá trị  là True hoặc cả hai đều là True
Ví dụ  Nếu  age_category is ‘Senior_citizen’ || special_category is ‘handicapped’ thì giảm giá tua lữ hành. Giá cũng sẽ được giảm nếu ít nhất một điều kiện được thỏa mãn
!
Toán hạng đơn tử NOT. Chuyển giá trị từ True sang False và ngược lại.
Ví dụ: Quá trình thực thi các dòng lệnh tiếp tục cho đến khi kết thúc chương trình.

e. Các toán tử điều kiện
Toán tử điều kiện là một loại toán tử đặc biệt vì nó gồm ba thành phần cấu thành biểu thức điều kiện

Cú pháp :
<biểu thức 1> ? <biểu thức 2>: <biểu thức 3>;
biểu thức 1
Biểu thức logic. Trả trả về giá trị True hoặc False
biểu thức 2
Giá trị trả về nếu biểu thức 1 xác định là True
biểu thức 3
Giá trị trả về nếu biểu thức 1 xác định là False

Câu lệnh sau đây kiểm tra có những người đi làm bằng vé tháng có tuổi lớn hơn 65 không và gán một tiêu chuẩn cho họ. Nếu những người này có tuổi là 55, tiêu chuẩn gán là “Regular”

  CommuterCategory = (CommuterAge>65)?”Senior Citizen”: “Regular”

f. Toán tử gán
Toán tử gán (=) dùng để gán một giá trị vào một biến. Bạn có thể gán nhiều giá trị đến nhiều biến cùng một lúc.

Ví dụ đoạn lệnh sau gán một giá trị cho biến num. Thì giá trị trong biến num được gán cho nhiều biến trên một dòng lệnh đơn.

int num = 20000;
int p,q,r,s;
p=q=r=s=num;

Dòng lệnh cuối cùng được thực hiện từ phải qua trái. Đầu tiên giá trị ở biến num được gán cho ‘s’, sau đó giá trị của ‘s’ được gán cho ‘r’ và cứ tiếp như vậy.

g. Thứ tự ưu tiên của các toán tử
Các biểu thức được viết ra nói chung gồm nhiều toán tử. Thứ tự ưu tiên quyết định trật tự thực hiện các toán tử trên các biểu thức. Bảng dưới đây liệt kê thứ tự thực hiện các toán tử trong Java

Thứ tự
Toán tử
1.
Các toán tử đơn như +,-,++,--
2.
Các toán tử số học và các toán tử dịch như *,/,+,-,<<,>>
3.
Các toán tử quan hệ như >,<,>=,<=,= =,!=
4.
Các toán tử logic và Bit như &&,II,&,I,^
5.
Các toán tử gán như =,*=,/=,+=,-=



[Tự học lập trình Java] Bài 1: Chương trình JAVA đầu tiên

Chương trình sau đây cho phép hiển thị một thông điệp “My first program in Java”.

Để soạn thảo chương trình bạn có thể sử dụng 1 trong các công cụ lập trình phổ biến sau: Netbean, Eclipse, Jcreator. Đây là những công cụ hoàn toàn miễn phí.


Tiến hành soạn thảo (Ví dụ sau đây sử dụng công cụ Netbean7.4 để soạn thảo chương trình, các công cụ khác tiến hành tương tự)

Bước 1 - Tạo Project mới: File / New project

Bước 2 - Chọn: Java – Applications


Bước 3 - Đặt tên Project và class

Bước 4 - Soạn thảo chương trình dưới đây
// This is a simple program called “First.java”

package first;

public class First
{
public static void main(String args[])
 {
    System.out.println(“My first program in Java”);
 }
}

Lưu ý: Các bạn có thể xóa hết nội dung trong của sổ đi và gõ lại.

Bước 5 - Chạy chương trình: click RUN

Lưu ý:
Tên file đóng vai trò rất quan trọng trong Java. Chương trình biên dịch Java chấp nhận phần mở rộng .java. Trong Java, mã lệnh phải nằm trong các lớp. Bởi vậy tên lớp và tên file phải trùng nhau. Java phân biệt chữ hoa và chữ thường (case-sensitive).

Phân tích chương trình đầu tiên

// This is a simple program called “First.java”

Ký hiệu “// ” dùng để thuyết minh dòng lệnh. Trình biên dịch sẽ bỏ qua dòng thuyết minh này. Java còn hỗ trợ thuyết minh nhiều dòng. Loại thuyết minh này có thể bắt đầu với /* và kết thúc với */

/*This is a comment that

extends to two lines*/
/ *This is
a multi line

comment */

Dòng kế tiếp khai báo lớp có tên ‘First’. Để tạo một lớp thêm ta bắt đầu với từ khoá ‘class’, kế đến là tên lớp (và cũng chính là tên file).

class First: Tên lớp nói chung nên bắt đầu bằng chữ in hoa. Từ khoá ‘class’ khai báo định nghĩa lớp. ‘First’ là tên của lớp. Một định nghĩa lớp nằm trọn vẹn nằm giữa hai ngoặc móc mở ({) và đóng (}). Các ngoặc này đánh dấu bắt đầu và kết thúc một khối lệnh.

public static void main(String args[ ]): Đây là phương thức chính, từ đây chương trình bắt đầu việc thực thi của mình. Tất cả các ứng dụng java đều sử dụng một phương thức “main” này. Chúng ta sẽ tìm hiểu từng từ trong lệnh này.

Từ khoá ‘public’ là một chỉ định truy xuất. Nó cho biết thành viên của lớp có thể được truy xuất từ bất cứ đâu trong chương trình. Trong trường hợp này, phương thức “main” được khai báo ‘public’, bởi vậy JVM có thể truy xuất phương thức này.

Từ khoá ‘static’ cho phép main được gọi tới mà không cần tạo ra một thể hiện (instance) của lớp. Nhưng trong trường hợp này, bản copy của phương thức main được phép tồn tại trên bộ nhớ, thậm chí không có một thể hiện của lớp đó được tạo ra. Điều này rất quan trọng vì JVM trước tiên gọi phương thức main để thực thi chương trình. Vì lý do này phương thức main cần phải là tĩnh (static). Nó không phụ thuộc vào các thể hiện của lớp được tạo ra.

Từ khoá ‘void’ thông báo cho máy tính biết rằng phương thức sẽ không trả lại bất cứ giá trị nào khi thực thi chương trình.

Phương thức ‘main()’ sẽ thực hiện một số tác vụ nào đó, nó là điểm mốc mà từ đó tất cả các ứng dụng Java được khởi động.

‘String args[]’ là tham số dùng trong phương thức ‘main’. Các biến số trong dấu ngoặc đơn nhận từng thông tin được chuyển vào ‘main’. Những biến này là các tham số của phương thức. Thậm chí ngay khi không có một thông tin nào được chuyển vào ‘main’, phương thức vẫn được thực hiện với các dữ liệu rỗng – không có gì trong dấu ngoặc đơn.

‘args[]’ là một mảng kiểu “String”. Các đối số (arguments) từ các dòng lệnh được lưu vào mảng. Mã nằm giữa dấu ngoặc móc ({ }) của ‘main’ được gọi là ‘method block’. Các lệnh được thực thi trong ‘main’ cần được viết trong khối này.

System.out.println(“My first program in Java”);

Dòng lệnh này hiển thị chuỗi “My first program in Java” trên màn hình. Phát biểu ‘println()’ tạo ra một cổng xuất (output). Phương thức này cho phép hiển thị chuỗi được truyền vào ra ‘System.out’. Ở đây ‘System’ là một lớp đã định trước, nó cho phép truy nhập vào hệ thống và ‘out’ là một chuỗi xuất được kết nối với dấu nhắc (console).

*Phụ lục* Nhập, xuất trong Java 

Có nhiều phương thức nhập, xuất khác nhau trong Java, trong phần này mình giới thiệu phương thức nhập, xuất đơn giản nhất để các bạn tiện làm bài tập. Còn các phương thức khác các bạn sẽ xem tìm hiểu kỹ hơn ở phần sau.

- Xuất - In kết quả ra màn hình sử dụng câu lệnh:
  System.out.print("Xâu, ký tự, biến, biểu thức mà bạn cần in ra"); // in xong không xuống dòng
hoặc
  System.out.println("Xâu, ký tự, biến, biểu thức mà bạn cần in ra"); // in xong xuống dòng

Ví dụ: In ra tổng hai số a, b cho trước
   int a=4,b=5;
   System.out.print(" Tong cua "+ a +" cong "+b+" bang "+ (a+b)); // Trong đó "+" là toán tử nối xâu.
   //Kết quả: Tong cua 4 cong 5 bang 9

 - Nhập - Nhập dữ liệu từ bàn phím sử dụng phương thức Scanner.
  + Để sử dụng phương thức Scanner cần khai báo thư viện:
    import java.util.Scanner; // sau khai bao backage
  + Trước khi nhập bạn cần khai báo đối tượng Scanner
    Ví dụ: Scanner inp = new Scanner(System.in); // inp là đối tượng Scanner
  + Nhập dữ liệu cho biến:
    Ví dụ: Nhập dữ liệu cho một số nguyên
               int a;
               Scanner inp =new Scanner(System.in);
               a= inp.nextInt(); // bạn muốn nhập kiểu dữ liệu nào bạn cần chọn next_Kiểu dữ liệu tương ứng.

Ví dụ: Viết chương trình nhập vào 2 số nguyên, tính tổng 2 số đó.

package tinhtong;
import java.util.Scanner;
public class TinhTong
{

   public static void main(String[] arg) {
   int a,b;

   // nhap a, b
   Scanner inp=new Scanner(System.in);
   System.out.print("\n a= ");  
   a=inp.nextInt();
   System.out.print("\n b= ");
   b=inp.nextInt();

   // tinh tong
   int tong=a+b;
   System.out.print("\n Tong = "+tong);  
  }
}

--------------------------------------------------- 

Một số tài liệu và khoá học bổ ích dành cho bạn: 

# Tài liệu: Lập trình hướng đối tượng JAVA core dành cho người mới bắt đầu học lập trình [Click để xem]

# Khoá học online: Lập trình Java trong 4 tuần [Click để xem]


Đọc thêm các bài khác:

Bài 1: Chương trình JAVA đầu tiên
Bài 2: Các kiểu dữ liệu và toán tử trong
Bài 3: Các cấu trúc điều khiển trong Java
Bài 4 : Mảng và chuỗi trong Java
Bài 5: Lớp (class) và đối tượng (object) trong Java
Bài 6:Thừa kế (Inheritance) và đa hình (Polymorphism)
Ví dụ lập trình giao diện đồ họa với Java (GUI)
Ví dụ lập trình kết nối dữ liệu với Java (JDBC)
Ví dụ về lập trình Android