Bài 815 & 816 : Viết hàm tìm phân số dương đầu tiên và phân số dương cuối cùng trong danh sách liên kết đơn các phân số

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
167
168
169
170
171
172
173
174
175
176
177
#include<stdio.h>
#include<conio.h>
#include<Windows.h>

// Khai báo cấu trúc dữ liệu cho 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;
 }
}

// Hàm nhập 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 %d:",i);
  scanf("%d",&x.tuso);
  do{
   printf("\nNhap vao mau so cua phan so %d:",i);
   scanf("%d",&x.mauso);
   if(x.mauso==0)
   {
    printf("\nMau so 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);
 }
}

// Hàm xuất 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);
 }
}

// Hàm tìm phân số dương đầu tiên trong danh sách liên kết đơn các phân số .
void TimPhanSoDuongDauTien(LIST l)
{
 NODE*pNode;
 LIST Prs;
 INit(Prs);
 // Ta duyệt từ đầu danh sách đến cuối danh sách,tìm ra phân số dương đầu tiên thì thoát ra khỏi vòng lặp và in ra nó .
 for(pNode=l.pHead;pNode!=NULL;pNode=pNode->pNext)
 {
  if(pNode->Data.ketqua>=0)
  {
   break;
  }
 }
 printf("\nPhan So Duong Dau Tien La:%d/%d",pNode->Data);
}

// Hàm tìm phân số dương cuối cùng trong danh sách liên kết đơn các phân số .
void TimPhanSoDuongCuoiCung(LIST l)
{
 NODE*pNode;
 LIST Prs;
 INit(Prs);
 // Tìm phân số dương cuối cùng thì ta duyệt từ cuối danh sách -> đầu danh sách,tìm ra phân số dương đầu tiên => đó chính là phân số dương cuối cùng .
 for(pNode=l.pTail;pNode!=NULL;pNode=pNode->pNext)
 {
  if(pNode->Data.ketqua>=0)
  {
   break;
  }
 }
 printf("\nPhan So Duong Cuoi Cung La:%d/%d",pNode->Data);
}

// Hàm MeNu .
void MeNu()
{
 int tieptuc;
 LIST lst;
 quaylai:InPut(lst);
 printf("\n");
 printf("\n>>>>>>>>>>>>>>>>>Xuat Danh Sach Cac Phan So:<<<<<<<<<<<<<<<<<<<<<<\n");
 printf("\n");
 OutPut(lst);
 printf("\n");
 printf("\n>>>>>>>>>>>>>>>>>Phan So Duong Dau Tien:<<<<<<<<<<<<<<<<<<<<<\n");
 printf("\n");
 TimPhanSoDuongDauTien(lst);
 printf("\n");
 printf("\n>>>>>>>>>>>>>>>>>Phan So Duong Cuoi Cung:<<<<<<<<<<<<<<<<<<<<<<<\n");
 printf("\n");
 TimPhanSoDuongCuoiCung(lst);
 printf("\n");
 printf("\nBan co muon tiep tuc thuc hien chuong trinh 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 ?