努力尽今夕,少年犹可夸。这篇文章主要讲述数组指针;喝汽水问题相关的知识,希望能为你提供帮助。
#include<
stdio.h>
int main()
{
char str1[] = "hello bit.";
char str2[] = "hello bit.";
char* str3 = "hello bit.";
char* str4= "hello bit.";
if (str1 == str2)
{
printf("str1和str2相同\\n");
}
else
printf("str1和str2不同\\n");
if (*str3 == *str4)
{
printf("*str3和*str4相同\\n");
}
else
printf("*str3和*str4不同n");
return 0;
}
/*数组指针*/
int main()
{
int a[] = { 1, 2, 3, 4, 5 };
int b[] = { 2, 3, 4, 5, 6 };
int c[] = { 3, 4, 5, 6, 7 };
int *arr[] = { a, b, c };
int i = 0;
for (i = 0;
i <
3;
i++)
{
for (int j = 0;
j <
5;
j++)
{
/*printf("%d ", *(arr[i] + j));
*/
printf("%d ", arr[i][j]);
}
printf("\\n");
}
return 0;
}
/*调试结果:
1 2 3 4 5
2 3 4 5 6
3 4 5 6 7*/
int main()
{
int a = 10;
int *pa = &
a;
char b = w;
char* pb = &
b;
int arr[7] = { 1, 2, 3, 4, 5, 6, 7 };
int (*parr)[10] = &
arr;
//取出的是数组的地址
//parr是数组指针,指向数组的地址
//arr是数组名,指向数组的首地址-arr[0]
double* d[5];
double* (*pd)[5] = &
d;
//pd就是一个指针
return 0;
}
int main()
{
int arr[10] = { 0 };
int (*parr)[10] = &
arr;
printf("%p\\n", arr);
printf("%p\\n", parr);
printf("%p\\n", arr+1);
printf("%p\\n", parr+1);
return 0;
}
/*调试结果相同,意义不同:
010FFB7C
数组首元素的地址
010FFB7C
指向数组的地址
0093FCB0
跳过一个数组元素
0093FCD4
跳过一个数组
*/
/*数组名是数组首元素的地址
但是两个例外:
1.sizeof(数组名) -数组名表示整个数组,计算的是整个数组大小,单位是字节
2.&
数组名,数组名表示整个数组,取出的是整个数组的地址*/
void print1(int arr[3][5],int r,int c)
{
for (int i = 0;
i <
r;
i++)
{
for (int j = 0;
j <
c;
j++)
{
printf("%d ", arr[i][j]);
}
printf("\\n");
}
}
void print2(int (*p)[5], int r, int c)
{
for (int i = 0;
i <
r;
i++)
{
for (int j = 0;
j <
c;
j++)
{
printf("%d ", *(*(p + i) + j));
}
printf("%\\n");
}
}
int main()
{
int arr[3][5] = { { 1, 2, 3, 4, 5 }, { 2, 3, 4, 5, 6 }, { 3, 4, 5, 6, 7 } };
//int (*p) = &
arr;
print1(arr, 3, 5);
//print2(arr, 3, 5);
return 0;
}
/*调试结果:
1 2 3 4 5
2 3 4 5 6
3 4 5 6 7*/
/*喝汽水问题:1元1瓶汽水,两空瓶可以换一瓶汽水,20元可以喝多少汽水*/
int main()
{
int n = 0;
int sum = 0;
int s = 0;
scanf("%d", &
n);
while (n>
1)
{
sum = sum + n ;
n = n / 2 ;
}
printf("%d", sum);
return 0;
}
/*方法2:*/
int main()
{
int n = 0;
scanf("%d", &
n);
int sum = n;
while (n >
1)
{
sum = sum+(n / 2);
n = (n / 2) + (n % 2);
}
printf("%d", sum);
return 0;
【数组指针;喝汽水问题】}
推荐阅读
- 介绍一款开源电商网站的购物车添加功能的实现
- 大厂算法面试之leetcode精讲3.动态规划
- 微服务架构中,二次浅封装实践
- 巧用云函数打造微信网页授权公用服务
- Flutter 专题15 图解 ListView 异步加载数据与等待#yyds干货盘点#
- 一个普通的开发日常-记一次缓存问题在实际开发中的解决方案
- flutter 中的列表的性能优化前奏#yyds干货盘点#
- #聊一聊WuKong编辑器#7 赞 6 建议 5 改进
- 02~文件通配符用户及用户组