C指针(1)——指针在数组中的应用(程序讲解)
2024-10-21 13:03:08
2-1.c数组指针的定义:
#include <stdio.h>
int main()
{
char str[]="China Beijing Fujian"; //定义数组str并进行初始化
char *pstr; //定义指针变量pstr
pstr=&str[6]; //初始化pstr,并使指针变量pstr指向数组str
printf("str:%s,str");
printf("pstr指向str[6]:%c\n,*pstr");
return 0;
}
结果:
str:China Beijing Fujian
pstr指向str[6]:B
2-2.c数组指针的引用
#include <stdio.h>
int main(void)
{
char str[]="China Beijing Fujian"; //定义数组str并进行初始化
char *pstr; //定义指针变量pstr
printf("str:%s\n",str); //输出数组str,%s表示字符串
pstr=str; //初始化指针变量pstr,pstr指向数组str;pstr和str指向数组str首地址
printf("pstr->str:%s\n",pstr); //以%s的形式输出pstr指向的数组元素
printf("&str=%p\n",&str); //%p指针的值,输出数组名str的地址,即&str。连续数组空间的首地址,即str[0]的地址
printf("pstr=%p\n",pstr); //输出指针变量pstr的值。因为pstr指向数组str,pstr的值就是str的地址,也是数组元素,str[0]的地址
printf("&str[0]=%p\n",&str[0]);
return 0;
}
结果:
str:China Beijing Fujian
pstr->str:China Beijing Fujian
&str=0x7fffd12e1c80
pstr=0x7fffd12e1c80
2-3
#include <stdio.h>
int main(void)
{
char str[]="China Fujian";
char *pstr;
pstr=str;
while(*pstr)
{
printf("%c:%p\n",*pstr,pstr); //%c单个字符,第一次执行时,pstr指向str[0],输出str[0]以及&str[0]
pstr++; //让指针指向下一个数组元素
}
return 0;
}
结果:
C:0x7fff13c1f1b0
h:0x7fff13c1f1b1
i:0x7fff13c1f1b2
n:0x7fff13c1f1b3
a:0x7fff13c1f1b4
:0x7fff13c1f1b5
F:0x7fff13c1f1b6
u:0x7fff13c1f1b7
j:0x7fff13c1f1b8
i:0x7fff13c1f1b9
a:0x7fff13c1f1ba
n:0x7fff13c1f1bb
2-4.c数组的下标表示法
#include <stdio.h>
#define WEEKNUM 7 //定义一个宏
int main(void)
{
int temp;
int week[WEEKNUM]={1,2,3,4,5,6,7};
printf("please input today is:");
scanf("%d",&temp);
if(temp<=WEEKNUM)
{
printf("tomorrow is :%d\n",week[temp]); //%d十进制有符号字符
}
else
{
printf("Error \n");
}
return 0;
}
结果:
please input today is:4
tomorrow i
2-5
#include <stdio.h>
#define LEN 8
int main(void)
{
char i;
char str[LEN]="Fujian";
printf("str:%s\n",str);
for(i=0;i<LEN;i++)
{
printf("%c:%p\n",str[i],&str[i]);
}
return 0;
}
结果:
str:Fujian
F:0x7fff3f5c5d20
u:0x7fff3f5c5d21
j:0x7fff3f5c5d22
i:0x7fff3f5c5d23
a:0x7fff3f5c5d24
n:0x7fff3f5c5d25
:0x7fff3f5c5d26
:0x7fff3f5c5d27
2-6.c数组的指针表示法
#include <stdio.h>
#define LEN 10
int main(void)
{
char str[LEN]={'A','B','C','D','E','F','G','H','I','J'};
char idx,*pstr;
pstr=str;
printf("please input (0-9)and ENTER:\n");
scanf("%d",&idx);
if(idx<LEN)
{
printf("The character is:%c\n",*(pstr+idx)); //patr指向数组str,即指向数组的第一个元素str[0],当运行pstr+idx运算后,,指针pstr指向str[idx],*(patr+idx)就是数组元素str[idx]
}
else
{
printf("The idx is overflow \n");
}
return 0;
结果:
please input (0-9)and ENTER:
4
The character is:E
2-8.c数组的下标法和指针
#include <stdio.h>
#define LEN 15
int main(void)
{
char str[LEN]="Fujian.2018";
char idx,*pstr;
for(idx=0;idx<LEN;idx++)
{
printf("%c",str[idx]); //下标法
}
printf("\n");
pstr=str;
while(*pstr)
{
printf("%c",*(pstr+idx)); //指针法
pstr++;
}
printf("\n");
return 0;
}
结果:
Fujian.2018
2-9.c指针数组的引用
#include <stdio.h>
int main(void)
{
char *str[]={"Fujian","Huian"}; //定义数组str并初始化
printf("str[0]:%s\n",str[0]); //%s一次性输出一个字符串,若要一次性输出一个字符串需要知道字符串的首地址,str[0]即为首地址
printf("str[1]:%s\n",str[1]);
return 0;
}
结果:
str[0]:Fujian
str[1]:Huian
2-10
#include<stdio.h>
int main()
{
char temp;
char *str[]={"IllgalDay","Monday","Tuesday","Wednesday","Thursday","Friday","Saturday","Sunday"};
printf("please input number:\n");
scanf("%d",&temp);
if(temp<7)
{
switch(temp)
{
case 0:
printf("Ingall day\n");
break;
case 1:
printf("Monday\n");
break;
case 2:
printf("Tuesday\n");
break;
}
}
return 0;
}
结果:
please input number:
1
Monday
2-11.c字符串指针的引用
#include <stdio.h>
int main(void)
{
char *str="Fujian 2018"; //相当于 char *str; str ="Fujian 2018";
printf("%s\n",str); //指针变量str指向字符串的“Fujian 2018”的首地址,这里仅仅是指向不是赋值
return 0;
}
结果:
Fujian 2018
2-12数组方式实现
#include <stdio.h>
int main(void)
{
char str[]="Fujian 2018"; //定义数组,并进行初始化
printf("%s\n",str);
return 0;
}
结果:
Fujian 2018
利用数组形式定义字符串就需要知道字符串大小,而指针形式则没有这个限制
2-13
#include <stdio.h>
int main()
{
char *str="Fujian 2018";
printf("%s\n",str); //%s字符串
printf("%p\n",str); //%p指针,输出str,字符串首地址
while(*str)
{
printf("%c",*str); //输出字符
printf(" %p\n",str); //输出字符地址
str++;
}
return 0;
}
结果:
Fujian 2018
0x4006c8
F 0x4006c8
u 0x4006c9
j 0x4006ca
i 0x4006cb
a 0x4006cc
n 0x4006cd
0x4006ce
2 0x4006cf
0 0x4006d0
1 0x4006d1
8 0x4006d2
一步一个脚印......
最新文章
- 几何服务,cut功能,输入要素target(修改后)内容。
- mysql case when then end学习
- 【Python】 sorted函数
- 使用FlashFXP V3.8烈火汉化绿色版软件连接Linux
- P2P之UDP穿透NAT原理
- 团队作业8——Beta项目(冲刺计划)
- Django----模板层
- [Swift]LeetCode848. 字母移位 | Shifting Letters
- 福州大学软件工程1916|W班 第2次作业成绩排名
- js 快速生成数组的方法
- 从 0 开始手写一个 Mybatis 框架,三步搞定!
- Ansible playbook roles
- vue:不同环境配置不同打包命令
- [leetcode]70. Climbing Stairs爬楼梯
- OpenEXR-2.2.0在Win7 x64系统下的安装方法
- Redis主从同步分析(转)
- 使用mmap可以方便地添加共享内存
- Executors相关的类(线程池)
- kth-smallest-element-in-a-sorted-matrix
- leetcode 16. 3Sum Closest JAVA
热门文章
- c# 父类的引用指向子类的实例
- 【起航计划 015】2015 起航计划 Android APIDemo的魔鬼步伐 14 App->;Activity->;Translucent Blur 模糊背景
- centos7 gearmand-1.1.15打包rpm
- COGS 678. 双重回文数
- c++中explicit关键字用法
- 正交矩阵、正规矩阵和酉矩阵(转自Ramble Over The Cloud~)
- python 字符串部分总结
- 利用Js或Css滤镜实现IE6中PNG图片半透明效果 IE6PNG妥妥的
- 【转】android中的Style与Theme
- app上线