Trang chủ Tin Học Lớp 8 Hai số nguyên dương x, y được gọi là nguyên...

Hai số nguyên dương x, y được gọi là nguyên tố cùng nhau nếu có ước chung lớn nhất của hai số x, y là 1. Cho dãy số A gồm có n phần tử nguyên dương đếm xem t

Câu hỏi :

Hai số nguyên dương x, y được gọi là nguyên tố cùng nhau nếu có ước chung lớn nhất của hai số x, y là 1. Cho dãy số A gồm có n phần tử nguyên dương đếm xem trong dãy A có bao nhiêu cặp nguyên tố cùng nhau. Ví dụ dãy A là 2 5 7 24 13 17 thì có các cặp nguyên tố cùng nhau là: (2, 5), (2, 7), (2, 13), (2,17), (5, 7), (5, 13), (5, 24), (5, 17), (7, 24), (7, 13), (7, 17), (24, 13), (24, 17), (13, 17) có 14 cặp nguyên tố cùng nhau. Dữ liệu: primefr.inp có cấu trúc như sau: - Dòng 1 ghi số n (n100000). - Dòng tiếp theo ghi n phần tử mỗi số cách nhau một dấu cách (ai109 ). Kết quả: ghi vào file primefr.out số cặp nguyên tố cùng nhau. Không có cặp nào ghi -1

Lời giải 1 :

uses crt ;
 const 
    fi = 'primefr.inp' ;
    fo = 'primefr.out' ;
   var f : text ;
 a : array[1..100] of longint ;
     i, d , n : longint ;
 function prime(n :longint) : boolean ;
    var i : longint;
         begin
        if n = 2 then prime := True
            else prime := False ;
        for i:=2 to trunc(sqrt(n)) do 
            if n mod i = 0 then
                     begin
                    prime :=false ;
                    break ; 
                     end ;
         end ;
begin
 i := 1 ;
    assign(f,fi) ;
      reset(f) ; 
    read(f,n) ;
    for i := 1 to n do read(f,a[i]);
      close(f);
    for i := 1 to n do 
        if prime(a[i]) = True then inc(d);
    if d = 0 then d := -1 
        else d := sqr(d);
    assign(f,fo) ;
        rewrite(f);
    write(f,d);
       close(f);
end .

Thảo luận

Lời giải 2 :

uses crt;
var v,r:text;
i,n,j,t,d:integer;
a:Array[1..100] of longint;

function ktuoc(x,y:longint):integer;
begin
while x<>y do
 if x>y then x:=x-y else y:=y-x;
ktuoc:=x;
end;

begin
clrscr;
assign(v,'primefr.inp');
reset(v);
readln(v,n);
for i:=1 to n do read(v,a[i]);
assign(r,'primefr.out');
rewrite(r);
d:=0;
for i:=1 to n-1 do
for j:=i+1 to n do
 if (ktuoc(a[i],a[j])=1) then
 begin
  d:=d+1;
  t:=1;
 end;
if t=0 then write(r,'-1')
else write(r,d);
close(r);
close(v);
end.

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 :))

Liên hệ hợp tác hoặc quảng cáo: gmail

Điều khoản dịch vụ

Copyright © 2021 HOCTAPSGK