1.c��ָ��Դ��
2.求C语言直接插入排序,指针针原选择排序,源码c语冒泡排序的指针针原源代码,能直接运行的源码c语最好,谢谢
3.c与指针的指针针原问题。下面是源码c语openrtsp 源码图像处理的源代码,很基础的指针针原c。求大神指点。源码c语
c��ָ��Դ��
源代码如下:#include<stdio.h>
#include<stdlib.h>
int main(){
int a[5];
int *p=a; //定义一个整型指针变量p,指针针原使它指向一个5个元素的一维数组.
int i;
printf("Please input:");
for(i=0;i<5;i++)
scanf("%d",p+i); //使用指针移动的方式,输入5个整型数组元素.
int *q=(int*)malloc(sizeof(int)*5); //malloc函数动态分配5个整型数的地址空间。
printf("Please input:");
for(i=0;i<5;i++)
scanf("%d",源码c语q+i); //使用数组下标的方式输入5个整型元素。
for(i=0;i<5;i++)
if(p[i]>q[i]){
int t=p[i];
p[i]=q[i];
q[i]=t;
}
for(i=0;i<5;i++) //使用指针p和q分别访问两组数据
printf("%d",指针针原p[i]);
putchar('\n');
for(i=0;i<5;i++)
printf("%d",q[i]);
putchar('\n');
printf("p=%x\n",p); //分别输出交换后的两组数。
printf("a=%x\n",源码c语a);
printf("q=%x\n",q);
free(q);
q=NULL;//按十六进制方式输出p、a和q的指针针原源码的加法地址。
return 0;
}
运行结果如下:
扩展资料:
指针的源码c语初始化、动态分配内存的指针针原方法
指针的初始化
对指针进行初始化或赋值只能使用以下四种类型的值 :
1. 0 值常量表达式,例如,在编译时可获得 0 值的整型 const对象或字面值常量 0。
2. 类型匹配的对象的地址。
3. 另一对象末的下一地址。
4. 同类型的有源码奶粉另一个有效指针。
把 int 型变量赋给指针是非法的,尽管此 int 型变量的值可能为 0。但允
许把数值 0 或在编译时可获得 0 值的 const 量赋给指针:
int ival;
int zero = 0;
const int c_ival = 0;
int *pi = ival; // error: pi initialized from int value of ival
pi = zero;// error: pi assigned int value of zero
pi = c_ival;// ok: c_ival is a const with compile-time value of 0
pi = 0;// ok: directly initialize to literal constant 0
除了使用数值 0 或在编译时值为 0 的 const 量外,还可以使用 C++ 语言从 C 语言中继承下来的预处理器变量 NULL,该变量在 cstdlib头文件中定义,其值为 0。
如果在代码中使用了这个预处理器变量,则编译时会自动被数值 0 替换。因此,把指针初始化为 NULL 等效于初始化为 0 值 [3] :
// cstdlib #defines NULL to 0
int *pi = NULL; // ok: equivalent to int *pi = 0;
动态分配内存的方法
new可用来生成动态无名变量
(1)new可用来生成动态无名变量
如 int *p=new int;
int *p=new int []; //动态数组的大小可以是变量或常量;而一般直接声明数组时,数组大小必须是狮子鱼源码常量
又如:
int *p1;
double *p2;
p1=new int⑿;
p2=new double [];
l 分别表示动态分配了用于存放整型数据的内存空间,将初值写入该内存空间,并将首地址值返回指针p1;
l 动态分配了具有个双精度实型数组元素的数组,同时将各存储区的首地址指针返回给指针变量p2;
对于生成二维及更高维的数组,应使用多维指针。
以二维指针为例
int **p=new int* [row]; //row是二维数组的行,p是vb导入源码指向一个指针数组的指针
for(int i=0; i<row; i++)
p[i]=new int [col]; //col是二维数组的列,p是指向一个int数组的指针
删除这个二维数组
for(int i = 0; i < row;i++)
delete []p[i]; //先删除二维数组的列
delete []p;
⑵使用完动态无名变量后应该及时释放,要用到 delete 运算符
delete p; //释放单个变量
delete [ ] p;//释放数组变量(不论数组是几维)
相比于一般的变量声明,使用new和delete 运算符可方便的使用变量。
百度百科-指针
百度百科-动态分配内存
求C语言直接插入排序,选择排序,冒泡排序的源代码,能直接运行的最好,谢谢
插入排序:用指针和插入排序法对数组中个整数按由小到大排序。
#include"stdio.h"
#include"conio.h"
main()
{
inta[],r[];
int *p;
int i,j;
for(i=0;i<;i++)
{
p=&a[i];
printf("pleasescan the NO: %d\n",i);
scanf("%d",p); /*因为p是指针变量,本身代表地址,所以不需加&符号*/
r[i+1]=a[i];
} /*以上for循环是将从键盘输入的个数依次放到a[0..9]和r[1..]中*/
r[0]=1;
for(i=2;i<=;i++)
{
r[0]=r[i];
j=i-1;
while(r[j]>r[0])
{
r[j+1]=r[j];
j--;
}
r[j+1]=r[0];
} /*以上for循环是将数组r[1..]中的数用插入法进行从小到大的顺序排序*/
for(i=1;i<=;i++) /*将排好序后的数组中的元素依次输出*/
{
p=&r[i];
printf("frommin to max the NO: %d value=%d\n",i,*p);
}
}
给分的话,剩下的在答
c与指针的问题。下面是图像处理的源代码,很基础的c。求大神指点。
上面那个是C++中的引用,这样写当然是可以的,引用比如有个人名字叫明天,朋友们又叫他小明,同一个人,无论怎么叫都是他;
下面那个是指针,当然不行。引用又不等于指针;指针是说另外有一个变量存了这个变量的地址,但是另外这个变量肯定不等于这个变量啊,就是这么回事。