Bài 818 : Viết hàm kiểm tra danh sách đơn các phân số có tồn tại phân số âm hay không ?

Tải Code về máy

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
#include<stdio.h>
#include<conio.h>
#include<Windows.h>
#define bool

// Khai báo cấu trúc dữ liệu danh sách liên kết đơn các phân số .
struct phanso
{
 int tuso;
 int mauso;
 float ketqua;
};
typedef struct phanso PHANSO;

struct node
{
 PHANSO Data;
 node*pNext;
};
typedef struct node NODE;

struct list
{
 NODE*pHead;
 NODE*pTail;
};
typedef struct list LIST;

// Khởi tạo danh sách liên kết đơn các phân số .
void INit(LIST &l)
{
 l.pHead=NULL;
 l.pTail=NULL;
}

// Tạo các Node trong danh sách liên kết đơn các phân số .
NODE*getnode(PHANSO x)
{
 NODE*p;
 p=new NODE;
 if(p==NULL)
  return NULL;
 p->Data=x;
 p->pNext=NULL;
 return p;
}

// Thêm vào cuối danh sách liên kết đơn các phân số .
void AddTail(LIST &l,NODE*new_ele)
{
 if(l.pHead==NULL)
 {
  l.pHead=new_ele;
  l.pTail=l.pHead;
 }
 else
 {
  l.pTail->pNext=new_ele;
  l.pTail=new_ele;
 }
}

// Nhập dữ liệu danh sách liên kết đơn các phân số .
void InPut(LIST &l)
{
 int n;
 quaylai:printf("\nNhap vao so luong cac phan so:");
 scanf("%d",&n);
 if(n<0)
 {
  printf("\nSo ban nhap vao khong hop le!Xin vui long nhap lai!");
  goto quaylai;
 }
 INit(l);
 for(int i=1;i<=n;i++)
 {
  PHANSO x;
  printf("\n>>>>>>>>>>>>>>>>>Nhap Vao Phan So Thu %d:<<<<<<<<<<<<<<<<<<<<<\n",i);
  printf("\n");
  printf("\nNhap vao tu so cua phan so thu %d:",i);
  scanf("%d",&x.tuso);
  do{
   printf("\nNhap vao mau so cua phan so thu %d:",i);
   scanf("%d",&x.mauso);
   if(x.mauso==0)
   {
    printf("\nMau so nhap vao khong hop le!Xin vui long nhap lai!");
   }
  }while(x.mauso==0);
  if(x.mauso<0)
  {
   x.tuso=x.tuso*-1;
   x.mauso=x.mauso*-1;
  }
  x.ketqua=(x.tuso*1.0)/x.mauso;
  NODE*p=getnode(x);
  AddTail(l,p);
 }
}

// Xuất dữ liệu danh sách liên kết đơn các phân số .
void OutPut(LIST l)
{
 int dem=0;
 for(NODE*p=l.pHead;p!=NULL;p=p->pNext)
 {
  dem++;
  printf("\nPhan So Thu %d La:%d/%d",dem,p->Data);
 }
}

// Kiểm tra danh sách có toàn phân số dương hay không ? 
void KiemTra(LIST l)
{
 int Co;
 bool Co=false;
 NODE*pNode;
 LIST Prs;
 INit(Prs);
 for(pNode=l.pHead;pNode!=NULL;pNode=pNode->pNext)
 {
  // Để kiểm tra danh sách có toàn phân số dương hay không thì ta chỉ cần đặt điều kiện chỉ cần tìm đc kết quả 1 phân số có giá trị âm thì => NO , ngược lại nếu không tìm thấy phân số nào có giá trị âm => YES .
  if(pNode->Data.ketqua<0)
  {
   Co=true; // khai báo biến bool .
  }
 }
 if(Co==true)
 {
  printf("\nYES");
 }
 else
 {
  printf("\nNO");
 }
}

// Hàm MeNu .
void MeNu()
{
 int tieptuc;
 LIST lst;
 quaylai:InPut(lst);
 printf("\n");
 printf("\n>>>>>>>>>>>>>>>>>>Cac Phan So Co Trong Danh Sach La:<<<<<<<<<<<<<<<<<<<<<<<<\n");
 printf("\n");
 OutPut(lst);
 printf("\n");
 printf("\n>>>>>>>>>>>>>>>>> Danh Sach Co Ton Tai Phan So Am Hay Khong ? <<<<<<<<<<<<<<<<<<<<\n");
 printf("\n");
 KiemTra(lst);
 printf("\n");
 printf("\nBan co muon tiep tuc thuc hien chuong trinh nua hay khong ? Neu co bam phim C,nguoc lai bam bat ky 1 phim nao khac de ket thuc!");
 tieptuc=getch();
 if(tieptuc=='c'||tieptuc=='C')
 {
  system("cls");
  goto quaylai;
 }
}

// Hàm chính .
void main()
{
 MeNu();
}

Nhận xét

Bài đăng phổ biến từ blog này

Bài 17 : Viết chương trình nhập số nguyên lớn N (khai báo:long N) có k chữ số

Bài Tập Cây Nhị Phân Tìm Kiếm

Bài 22 : Viết chương trình nhập vào số nguyên dương n gồm 5 chữ số,kiểm tra xem các chữ số n có phải là số đối xứng hay không ?