数组指针与指针数组

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
1.区分指针数组和数组指针
2.掌握其应用
3.多看书,理解其深层含义

//void test(int *p)
//{
//
//}
//int main()
//{
// int num;
// int *p2 = #
// test(p2);
// return 0;
//}
//int main()
//{
// void test(int arr[])
// {}
// void test(int arr[10])
// {}
// void test(int *arr)
// {}
// void test2(int *arr[20])
// {}
// void test2(int **arr)
// {}
// int main()
// {
// int arr[10] = { 0 };
// int arr2[20] = { 0 };
// test(arr);
// test2(arr2);
// }
//int main()
//{
// int(parr3[10])[5];
// return 0;
//}
//int main()
//{
// /char ch = ‘w’;
// char
pc = &ch;
// pc = ‘e’;/
// const char
p = “abcdef”;//常量字符串,不能被修改,const修饰的
p,这样才能保证p不会被改
// printf("%s\n", p);
// return 0;
//}

//int main()
//{
// char arr1[] = “abcdef”;//arr1代表首元素的地址
// char arr2[] = “abcdef”;//arr2也代表首元素地址,两个地址(空间)肯定不一样 字符串的比较不能用=,只能用strcmp函数
// charp1 = “abcdef”;//常量字符串会一直保持不变
// char
p2 = “abcdef”;
// if (arr1 == arr2) 《 剑指offer》
// {
// printf(“arr1 == arr2”);//no
//
// }
// if (p1 == p2)
// {
// printf(“p1 == p2”);//ok
// }
// return 0;
//}

//
//int main()
//{
// //char* a[5];//指针数组
// //数组指针 指向数组的指针
// //整型指针 int*
// //字符指针 char*
// int arr[10];
// int(*p)[10] = &arr;//数组指针
// return 0;
//}
//&数组名代表数组的地址
//数组名代表首元素的地址,他俩值一样,意义却不一样。

//数组指针的使用
//void print(int arr, int x, int y)
//{
// int i = 0;
// int j = 0;
// for (i = 0; i < x; i++)
// {
// for (j = 0; j < y; j++)
// {
// printf("%d “, arr[i][j]);
// }
// printf(”\n");
// }
//
//}
//void print(int (*arr)[5], int x, int y)
//{
// int i = 0;
// int j = 0;
// for (i = 0; i < x; i++)
// {
// for (j = 0; j < y; j++)
// {
// printf("%d\n", ((arr + i) + j));//运用数组指针
// }
// printf("\n");
// }
//}
//int main()
//{
// //int arr[10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9.10 };
// ////int p = arr; 如果遍历的话,直接p+1,一直+
// //int(*p)[10] = &arr;
// //int i = 0;
// //for (i = 0; i < 10; i++)
// //{
// // printf("%d\n", (*p)[i]);
// //}
// int arr[3][5] = { 1, 2, 3, 4, 5, 2, 3, 4, 5, 6, 3, 4, 5, 6, 7 };
// print(arr, 3, 5);
//
// return 0;
//}
//void test(int *p)
//{
//
//}
//int main()
//{
// int num;
// int *p2 = #
// test(p2);
// return 0;
//}
//int main()
//{
// void test(int arr[])
// {}
// void test(int arr[10])
// {}
// void test(int *arr)
// {}
// void test2(int *arr[20])
// {}
// void test2(int **arr)
// {}
// int main()
// {
// int arr[10] = { 0 };
// int arr2[20] = { 0 };
// test(arr);
// test2(arr2);
// }
//int main()
//{
// int(parr3[10])[5];
// return 0;
//}
//int main()
//{
// /char ch = ‘w’;
// char
pc = &ch;
// pc = ‘e’;/
// const char
p = “abcdef”;//常量字符串,不能被修改,const修饰的
p,这样才能保证p不会被改
// printf("%s\n", p);
// return 0;
//}

//int main()
//{
// char arr1[] = “abcdef”;//arr1代表首元素的地址
// char arr2[] = “abcdef”;//arr2也代表首元素地址,两个地址(空间)肯定不一样 字符串的比较不能用=,只能用strcmp函数
// charp1 = “abcdef”;//常量字符串会一直保持不变
// char
p2 = “abcdef”;
// if (arr1 == arr2) 《 剑指offer》
// {
// printf(“arr1 == arr2”);//no
//
// }
// if (p1 == p2)
// {
// printf(“p1 == p2”);//ok
// }
// return 0;
//}

//
//int main()
//{
// //char* a[5];//指针数组
// //数组指针 指向数组的指针
// //整型指针 int*
// //字符指针 char*
// int arr[10];
// int(*p)[10] = &arr;//数组指针
// return 0;
//}
//&数组名代表数组的地址
//数组名代表首元素的地址,他俩值一样,意义却不一样。

//数组指针的使用
//void print(int arr, int x, int y)
//{
// int i = 0;
// int j = 0;
// for (i = 0; i < x; i++)
// {
// for (j = 0; j < y; j++)
// {
// printf("%d “, arr[i][j]);
// }
// printf(”\n");
// }
//
//}
//void print(int (*arr)[5], int x, int y)
//{
// int i = 0;
// int j = 0;
// for (i = 0; i < x; i++)
// {
// for (j = 0; j < y; j++)
// {
// printf("%d\n", ((arr + i) + j));//运用数组指针
// }
// printf("\n");
// }
//}
//int main()
//{
// //int arr[10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9.10 };
// ////int p = arr; 如果遍历的话,直接p+1,一直+
// //int(*p)[10] = &arr;
// //int i = 0;
// //for (i = 0; i < 10; i++)
// //{
// // printf("%d\n", (*p)[i]);
// //}
// int arr[3][5] = { 1, 2, 3, 4, 5, 2, 3, 4, 5, 6, 3, 4, 5, 6, 7 };
// print(arr, 3, 5);
//
// return 0;

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>

//void test(int *p)
//{
//
//}
//int main()
//{
// int num;
// int *p2 = #
// test(p2);
// return 0;
//}
//int main()
//{
// void test(int arr[])
// {}
// void test(int arr[10])
// {}
// void test(int *arr)
// {}
// void test2(int *arr[20])
// {}
// void test2(int **arr)
// {}
// int main()
// {
// int arr[10] = { 0 };
// int arr2[20] = { 0 };
// test(arr);
// test2(arr2);
// }
//int main()
//{
// int(parr3[10])[5];
// return 0;
//}
//int main()
//{
// /char ch = ‘w’;
// char
pc = &ch;
// pc = ‘e’;/
// const char
p = “abcdef”;//常量字符串,不能被修改,const修饰的
p,这样才能保证p不会被改
// printf("%s\n", p);
// return 0;
//}

//int main()
//{
// char arr1[] = “abcdef”;//arr1代表首元素的地址
// char arr2[] = “abcdef”;//arr2也代表首元素地址,两个地址(空间)肯定不一样 字符串的比较不能用=,只能用strcmp函数
// charp1 = “abcdef”;//常量字符串会一直保持不变
// char
p2 = “abcdef”;
// if (arr1 == arr2) 《 剑指offer》
// {
// printf(“arr1 == arr2”);//no
//
// }
// if (p1 == p2)
// {
// printf(“p1 == p2”);//ok
// }
// return 0;
//}

//
//int main()
//{
// //char* a[5];//指针数组
// //数组指针 指向数组的指针
// //整型指针 int*
// //字符指针 char*
// int arr[10];
// int(*p)[10] = &arr;//数组指针
// return 0;
//}
//&数组名代表数组的地址
//数组名代表首元素的地址,他俩值一样,意义却不一样。

//数组指针的使用
//void print(int arr, int x, int y)
//{
// int i = 0;
// int j = 0;
// for (i = 0; i < x; i++)
// {
// for (j = 0; j < y; j++)
// {
// printf("%d “, arr[i][j]);
// }
// printf(”\n");
// }
//
//}
//void print(int (*arr)[5], int x, int y)
//{
// int i = 0;
// int j = 0;
// for (i = 0; i < x; i++)
// {
// for (j = 0; j < y; j++)
// {
// printf("%d\n", ((arr + i) + j));//运用数组指针
// }
// printf("\n");
// }
//}
//int main()
//{
// //int arr[10] = { 1, 2, 3, 4, 5, 6, 7, 8, 9.10 };
// ////int p = arr; 如果遍历的话,直接p+1,一直+
// //int(*p)[10] = &arr;
// //int i = 0;
// //for (i = 0; i < 10; i++)
// //{
// // printf("%d\n", (*p)[i]);
// //}
// int arr[3][5] = { 1, 2, 3, 4, 5, 2, 3, 4, 5, 6, 3, 4, 5, 6, 7 };
// print(arr, 3, 5);
//
// return 0;
//}
//

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值