hàm malloc, alloc, realloc, free, cấp phát và giải phóng bộ nhớ động trong lập trình c
biến động được tạ ra khi chạy chương trình. thông qua con trỏ bộ nhớ được cấp phát và quản lý
các thao tác trên bộ nhớ và con trỏ nằm trong thư viện stdlib.h và alloc.h
các hàm cấp phát và giai phóng bộ nhớ: maaloc, alloc, realloc, free
chứa năng của hàm malloc là cấ phát 1 vùng nhớ có kích thowcs sizeví dụ: int *p;p=(int *)malloc(100);p=(int *)malloc(80*sizeof(int));
hàm free dùng để giải phóng bộ nhớ đã cấp phát.free(p);
ví dụ:#include<stdio.h>#include<conio.h>#include<stdlib.h>#include<string.h>void...
Wednesday, December 31, 2014
KIỂU FILE TRONG LẬP TRÌNH C
KIỂU FILE TRONG LẬP TRÌNH C
file là 1 tập hợp thông tin được lưu dưới 1 cái tên chung *.txt, *.exe
khai báo: file *tên biến; ở đây là biến con trỏ
file *open(char *tên file,char *kiểu mở);
kiểu mở là 1 trong các chuổi sau đây:
"rb":read only
"wb":write
"ab":thêm vào cuối file
"r+b":đọc và ghi
"w+b":tạo file mới để ghi và đọc
"a+b":mowrvaf thêm vào cuối file
ví dụ:
f=open("t1.txt","w+b");
đóng tập tin fclose(f);
fcloseall(f);
kiểm tra đọc đến cuối file chưa.
dùng hàm:
feof(f)=0 nếu chưa và =1 nếu đã hết;
đọc ghi số nguyên...
Sunday, December 28, 2014
sắp xếp chẵn trước, lẻ sau và tăng dần - bài tập c
.png)
//sắp xếp các phần tử của mảng sao cho các phần tử chẵn đứng trước, các phần tử lẻ đúng sau đông thời cũng sắp xếp tăng dần
#include<stdio.h>
#include<conio.h>
int a[10] = { 1, 5, 4, 8, 2, 9, 8, 6, 3, 9 };
int n = 10;
void sapxep(int a[], int n)
{
int i, j;
for (i = 0; i < n - 1;i++)
for (j = i + 1; j < n;j++)
if ((a[i] % 2 != 0 && a[j] % 2 == 0)
|| (a[i] % 2 == 0 && a[j] % 2 == 0 && a[i]>a[j])
...
viết hàm tính sin(x) - bài tập lập trình c
.png)
//viết hàm tính sin(x)
#include<stdio.h>
#include<conio.h>
#include<math.h>
double sin(double x)
{
double ps = x, i = 1, tong = x,dau=-1;
while (fabs(ps) > 0.00001)
{
ps = ps*x*x / ((i + 1)*(i + 2));
tong += dau*ps;
dau = -dau;
}
return tong;
}
void main()
{
double x;
printf("x="); scanf_s("%lf", &x);
printf("%lf\n", sin(x));
...
in ra màn hình tam giác pascal - bài tập c
.png)
//in ra màn hình tam giác pascal với số hàng bất kỳ nhập vào
#include<stdio.h>
#include<conio.h>
int tohop(int n, int k)
{
if (k == 1 || k == n) return 1;
return tohop(n - 1, k - 1) + tohop(n - 1, k);
}
void main()
{
int n;
printf("N="); scanf_s("%d", &n);
for (int i = 1; i <= n; i++)
{
for (int j = 1; j <= i; j++)
{
if (j == 1)
{
for (int m = 1; m <= n - i;m++) printf(" ");
...
liệt kê số bằng tổng ước số của nó - bài tập c
.png)
Viết chương trình tìm và in ra các số (<=1000) thỏa tính chất: số bằng tổng các ước số của nó. Ví dụ: 6 = 1 + 2 + 3.
liệt kê số bằng tổng ước số của nó - bài tập c
//liệt kê các số nhỏ hơn 1000 thỏa số bằng tổng các ước số của nó
#include<stdio.h>
#include<conio.h>
void so()
{
for (int i = 3; i < 1000; i++)
{
int tong = 0;
for (int j = 1; j < i;j++)
if (i%j == 0) tong += j;
if (tong == i) printf("%d\n",i);
...
tìm kiếm phần tử giá trị k trong mảng - bài tập c
.png)
tìm các phần tử có giá trị bằng k cho trước và hiện ra màn hình các phần tử đó.
//tìm các phần rử có giá trị bằng k cho trước và hiện ra màn hình các phần tử đó.
#include<stdio.h>
#include<conio.h>
int a[10] = { 1, 2, 3, 4, 3, 4, 2, 3, 4, 1 };
int n = 10;
void dem(int a[], int n, int k)
{
int b = 0;
for (int i = 0; i < n;i++)
if (a[i] == k) b++;
printf("co %d phan tu co gia tri %d\ncac phan tu do la:\n",b,k);
for...
tính số e - bài tập lập trình c
.png)
viết chương trình c tính số e và lũy thừa cơ số e
//tính số e, lũy thừa với số e
#include<stdio.h>
#include<conio.h>
#include<math.h>
double e(double x)
{
double tong = 1, i = 1, ps = 1;
while (ps > 0.00001)
{
ps = ps*x / i;
tong += ps;
i++;
}
return tong;
}
void main()
{
printf("e^1=%lf\ne^7=%lf\n", e(1),e(7));
...
tính số pi (3.14) - bài tập lập trình c
.png)
viết chương trình c, lập trình tính số pi (3.14)
//tính số pi
#include<stdio.h>
#include<conio.h>
#include<math.h>
double pi()
{
double dau,s=1,tong=1;
int n = 1;
while (fabs(s)>0.00001)
{
if (n % 2 == 0) dau = 1; else dau = -1;
s = dau / (2 * n + 1);
tong += s;
n++;
}
return tong*4;
}
void main()
{
printf("%.10lf\n", pi())...
Sunday, October 12, 2014
lập trình c: tìm BCNN bội chung nhỏ nhất của 2 số
.png)
viết chương trình c tìm BCNN bội chung nhỏ nhất của 2 hai số a và b nguyên dương
#include<stdio.h>
#include<conio.h>
void main()
{
int a, b, i = 2;
do
{
printf("nhap a>0,b>0\n");
scanf_s("%d%d", &a, &b);
} while (a <= 0 || b <= 0);
while (a%b!=0)
{
a = a / (i - 1)*i; i++;
}
printf("BCNN=%d", a);
_getch();
}
...
Saturday, October 11, 2014
tìm giá trị xuất hiện nhiều nhất trong mảng và số lần xuất hiện
.png)
lập trình c tìm phần tử xuất hiện nhiều nhất trong mảng và số lần xuất hiện của phần tử đó
#include<stdio.h>
#include<conio.h>
int a[100];
void main()
{
int i, n,j, max, gt, dem;
printf("nhap so phan tu cua mang:");
scanf_s("%d", &n);
for (i = 0; i < n; i++)
{
printf("a[%d]=", i + 1);
scanf_s("%d", &a[i]);
}
printf("mang da nhap:\n");
for (i = 0; i < n; i++) printf(" %d ", a[i]);
max = 1;
...
lập trình c tìm phần tử lớn thứ k trong mảng
.png)
viết chương trình c tìm phần tử lớn thứ k trong mảng
#include<stdio.h>
#include<conio.h>
int a[100];
void main()
{
int i, n, j,k,b,d;
printf("nhap so phan tu cua mang:");
scanf_s("%d", &n);
for (i = 0; i < n; i++)
{
printf("a[%d]=", i + 1);
scanf_s("%d", &a[i]);
}
printf("mang da nhap:\n");
for (i = 0; i < n; i++) printf(" %d ", a[i]);
for (i = 0; i < n-1;i++)
for (j = i + 1; j < n;j++)
...
lập trình c hiển thị các dãy con tăng trong mảng 1 một chiều
.png)
viết chương trình c hiển thị các dãy con tăng trong mảng 1 một chiều. ví dụ 1,2,3,1,3,2,4,5 thì in ra các dãy con tăng là 1,2,3 và 1,3 và 2,4,5
#include<stdio.h>
#include<conio.h>
int a[100];
void main()
{
int i, n, dem;
printf("nhap so phan tu cua mang:");
scanf_s("%d", &n);
for (i = 0; i < n; i++)
{
printf("a[%d]=", i + 1);
scanf_s("%d", &a[i]);
}
printf("mang da nhap:\n");
for (i = 0; i...
lập trình c: xóa phần tử trùng nhau trong mảng
.png)
viết chương trình c xóa bớt các phần tử giống nhau trong mảng sao cho mảng chỉ gồm các phần tử phân biệt
#include<stdio.h>
#include<conio.h>
int a[100];
void main()
{
int i, j, n, k, dem = 0;
printf("nhap so phan tu cua mang:");
scanf_s("%d", &n);
for (i = 0; i < n; i++)
{
printf("a[%d]=", i + 1);
scanf_s("%d", &a[i]);
}
printf("mang da nhap:\n");
for (i = 0; i < n; i++) printf(" %d ", a[i]);
...
Friday, October 10, 2014
lập trình c đếm số phần tử phân biệt của mảng bất kì
.png)
viết chương trình nhập vào 1 mảng bất kì và dếm xem có bao nhiêu phần tử phân biệt.
#include<stdio.h>
#include<conio.h>
int a[100];
void main()
{
int i, dem, n,j,k=1;
printf("nhap so phan tu cua mang:");
scanf_s("%d", &n);
for (i = 0; i < n; i++)
{
printf("a[%d]=",i + 1);
scanf_s("%d", &a[i]);
}
printf("mang da nhap la:\n");
for (i = 0; i < n; i++) printf(" %d ", a[i]);
for (i = 1; i < n;...
lập trình c tìm trong mảng có bao nhiêu phần tử có giá trị bằng k
.png)
viết chương trình c về mảng 1 chiều: đếm xem có bao nhiêu phần tử có giá trị bằng k và chỉ ra các phần tử đó
#include<stdio.h>
#include<conio.h>
int a[100];
void main()
{
int i, k, n, dem=0;
printf("nhap so phan tu cua mang: ");
scanf_s("%d", &n);
for (i = 0; i < n; i++)
{
printf("a[%d]=", i + 1);
scanf_s("%d", &a[i]);
}
printf("mang da nhap la:\n");
for (i = 0; i < n; i++) printf(" %d ",a[i]);
...
sắp xếp mảng a cho trước sao cho các phần tử lớn nhất ở đầu mảng, các phần tử bé nhất ở cuối mảng, các phần tử còn lại sắp xếp tăng dần
.png)
sắp xếp mảng a cho trước sao cho các phần tử lớn nhất ở đầu mảng, các phần tử bé nhất ở cuối mảng, các phần tử còn lại sắp xếp tăng dần#include<stdio.h>#include<conio.h>int a[100];void main(){ int demmin = 0, n, i, k, max, min, demmax = 0, j; printf("nhap so phan tu cua mang: "); scanf_s("%d", &n); for (i = 0; i < n; i++) { printf("a[%d]=", i + 1); scanf_s("%d", &a[i]); } printf("mang da nhap:\n"); for (i = 0; i < n; i++)...
Friday, October 3, 2014
lập trình c, chèn thêm phần tử x vào vị trí k trong mảng
.png)
viết chương trình c chèn thêm 1 phần tử có giá trị x vào vị trí thứ k trong mảng 1 chiều
#include<stdio.h>
#include<conio.h>
int a[100], b[100];
void main()
{
int i,j, n,k,x;
printf("nhap so phan tu cua mang: ");
scanf_s("%d", &n);
for (i = 0; i < n; i++)
{
printf("A[%d]=", i + 1);
scanf_s("%d", &a[i]);
}
printf("mang da nhap la: \n");
for (i=0;i<n;i++) printf(" %d ", a[i]);
printf("\nnhap...
lập trình c xóa k phần tử liên tục trên mảng bắt đầu từ vị trí x cho trước
.png)
viết chương trình c xóa k phần tử liên tục trên mảng bắt đầu từ vị trí x cho trước#include<stdio.h>#include<conio.h>int a[100], b[100];void main(){ int i, j, n, k, x,m=0; printf("nhap so phan tu cua mang: "); scanf_s("%d", &n); for (i = 0; i < n; i++) { printf("A[%d]= ", i + 1); scanf_s("%d", &a[i]); } printf("mang da nhap la: \n"); for (i = 0; i < n; i++) printf(" %d ", a[i]); do { printf("\nxoa may phan tu? k="); scanf_s("%d",...
lập trình c xóa tất cả các số nguyên tố có trong mảng
.png)
viết chương trình c xóa tất cả các số nguyên tố có trong mảng
#include<stdio.h>
#include<conio.h>
int a[100], b[100];
void main()
{
int i, n, k = 0, j,dem;
printf("nhap so phan tu cua mang: ");
scanf_s("%d", &n);
for (i = 0; i < n; i++)
{
printf("nhap phan tu thu %d: ", i + 1);
scanf_s("%d", &a[i]);
}
printf("mang dda nhap la:\n");
for (i = 0; i < n; i++) printf(" %d ", a[i]);
for (i = 0; i...
lập trình c xóa tất cả các phần tử là số chẵn trong mảng
.png)
viết chương trình c nhập vào 1 mảng bất kì và tiến hành xóa tất cả các phần tử là số chẵn có trong mảng, in ra màn hình mảng sau khi đã xóa .
#include<stdio.h>
#include<conio.h>
int a[100], b[100];
void main()
{
int i, n, k=0;
printf("nhap so phan tu cua mang: ");
scanf_s("%d", &n);
for (i = 0; i < n; i++)
{
printf("a[%d]= ", i + 1);
scanf_s("%d", &a[i]);
}
printf("mang da nhap la: \n");
for (i...
lập trình c xóa phần tử thứ k trong mảng 1 chiều
.png)
viết chương trình c xóa phần tử thứ k trong mảng và in ra màn hình mảng sau khi đã xóa đi phần tử đó
#include<stdio.h>
#include<conio.h>
int a[100];
int b[100];
void main()
{
int i, n,k,m=0;
printf("nhap so phan tu cua mang: ");
scanf_s("%d", &n);
for (i = 0; i < n; i++)
{
printf("nhap phan tu thu %d: ",i+1);
scanf_s("%d", &a[i]);
}
printf("mang ban vua nhap la:\n");
for (i = 0; i < n; i++)...
lập trình c sắp xếp mảng sao cho chẵn dồn về trước, lẻ dồn về sau
.png)
sắp xếp mảng sao cho tất cả các số chẵn dồn về trước, các số lẻ dồn về sau mảng và in ra màn hình mảng đã sắp xếp
#include<stdio.h>
#include<conio.h>
int a[100], c[100], l[100];
void main()
{
int i, j, n, m=0, k=0;
printf("nhap so phan tu cua mang: ");
scanf_s("%d", &n);
for (i = 0; i < n; i++)
{
printf("nhap phan tu thu %d: ", i + 1);
scanf_s("%d", &a[i]);
}
for (i = 0; i < n;i++)
if (a[i] %...
Thursday, October 2, 2014
lập trình c sắp xếp mảng tăng dần
.png)
viết chương trình c nhập vào 1 mảng bất kì và sắp xếp mảng theo thứ tự tăng dần rồi in ra màn hình mảng đã sắp xếp
#include<stdio.h>
#include<conio.h>
int a[100];
void main()
{
int i, j, n,k;
printf("nhap so phan tu cua mang: ");
scanf_s("%d", &n);
for (i = 0; i < n; i++)
{
printf("nhap phan tu thu %d: ", i + 1);
scanf_s("%d", &a[i]);
}
for (i = 0; i < n-1;i++)
for (j = i+1; j < n;j++)
if...
lập trình c (mảng 1 chiều) tìm tổng lớn nhất của k phần tử liên tếp
.png)
viết chương trình c : mảng 1 chiều, tìm tổng lớn nhất của k (cho trước) phần tử liên tiếp trên mảng
#include<stdio.h>
#include<conio.h>
int a[100];
int b[100];
void main()
{
int k,i,n,j;
printf("nhap so tu cua mang: ");
scanf_s("%d", &n);
for (i = 0; i < n; i++)
{
printf("nhap phan tu thu %d: ", i + 1);
scanf_s("%d", &a[i]);
}
printf("tong cua k phan tu lien tiep, nhap k= ");
scanf_s("%d", &k);
...
lập trình c in ra các phần tử không thuộc mảng và nhỏ hơn max của mảng
.png)
viết chương trình c tìm phần tử lớn nhất của mảng và in ra màn hình các số nguyên dương không thuộc mảng và nhỏ hơn "max" của mảng
#include<stdio.h>
#include<conio.h>
int a[100];
void main()
{
int i, n, j;
printf("nhap so phan tu cua mang: ");
scanf_s("%d", &n);
for (i = 0; i < n; i++)
{
printf("nhap phan tu thu %d: ", i + 1);
scanf_s("%d", &a[i]);
}
printf("cac so nguyen duong khong thuoc mang va...