C语言学习(6)
一、C语言中的指针
1. 指针的基本概念
指针:
也是一种变量,是一种特殊的变量(专门用来存放其它变量在内存中地址的)
int a;
float b;
一个变量有多个字节(内存中有多个地址编码),指针存放的是这个变量的首地址(最低的地址,起始位置的地址)
指针的定义:
类型 *指针的名字
比如: int *p; //定义了int类型的指针 *表示p是个指针
float *q;
char *p;
指针的使用:
第一种: 定义一个指针并初始化
int a=10;
int *p=&a; // & -->取地址符号(获取变量a在内存中的首地址)
第二种: 定义一个指针没有立马初始化
int a=10;
int *p; //定义了指针p,p存放谁的地址目前是不清楚的
p=&a;
指针的几种基本运算
第一种: 解引用
通过指针访问指向的变量里面的内容,或者通过指针修改指向的变量
使用解引用运算
*p; //把指针p解引用(取出指针p指向的地址里面的内容)
第二种:取地址
int a=100;
int *p=&a; //对a取地址
小结: 指针是C语言提供的一种间接访问变量的方法
第三种: 指针可以比较大小
指针比较大小---》就是把地址当成是数字来比较
#include <stdio.h> int main() { int a = 888; int *p = &a; //指针p指向a的首地址 //打印一下变量a在内存中首地址 printf("a的首地址是:%p\n", &a); printf("指针p中存放的地址是:%p\n", p); //指针的作用一: 通过指针访问它指向的地址中的数据内容 printf("传统的方法访问a的值:%d\n", a); printf("通过指针访问a的值: %d\n", *p); //解引用p //指针的作用二: 通过指针修改变量的值 *p = 666; printf("a被修改成了:%d\n", a); }
练习:
1. int a[5]; //键盘输入5个数,用指针实现判断这个五个数是不是完数
完数: 一个数等于自身公因子和 (去除本身)
比如: 6 ---》公因子(能被6整除就是它的公因子) 1 2 3
6= 1+2+3
7 --》 公因子 1
int *p= &a[0] // *p等价于a[0]
//如何求*p公因子--> *p分别除以1 2 3 ....*p只要能整除的就是公因子
p=&a[1]
#include <stdio.h> int main() { int *p, i, j = 0, k; int flag = 0; int input[5] = {0}; int temp = 0; int output[5] = {0}; printf("请输入5个数:\n"); for (i = 0; i < 5; i++) scanf("%d", &input[i]); for (i = 0; i < 5; i++) { p = &input[i]; //取地址 for (k = 1; k < *p; k++) { flag = *p % k; //取余判断是否整除 if (flag == 0) //整除为0 { temp += k; //将能够整除的k加起来 if (temp == *p) //判断是否为完数 { output[j++] = *p; //使用数组保存起来 } } } temp = 0; //使用完清空 } printf("以上5个数是完数的是:\n"); for (i = 0; i < j; i++) { printf("%d ", output[i]); } printf("\n"); return 0; }
作业:
1.基础题
输入字符串,分别统计出其中 英文字母、空格、数字和其它字符的个数。
求a+aa+aaa+aaaa+aa...a的值
比如:a是3,总共5项(变量n表示) 3+33+333+3333+33333结果是??
要求a和n从键盘输入
思路:3+33+333+3333+33333 ---》 3*(1+11+111+1111+11111)
#include <stdio.h> #include <math.h> //因为引用10的n次方才调用pow(10,n) int main() { int i, temp = 0, sum = 0, input_1, input_2; printf("Please enter 2 numbers!\n"); scanf("%d %d", &input_1, &input_2); for (i = 0; i < input_2; i++) //求和:1+11+111+...+i个1 { temp += (int)pow(10, i); //这里调用了math.h中的pow函数,使用10的n次方 sum += temp; //1+11+111+… //思路为:Num[n]=Num[n-1]*10+1; } sum *= input_1; //将总和乘于第一个数 printf("The final result is:%d\n", sum); return 0; }
2.写一个程序处理字符串A,处理规则是: 只要字符串B里面有的字符,不论大小写,一律从A字符串中删除 (用数组或者指针实现)
fdjjfDFDdjfjdf ---》 A字符串
AFafd ---》 B字符串
#include <stdio.h> #include <string.h> int main() { int i, j, k, len_1 = 0, len_2 = 0; char input_1[50], input_2[50]; printf("Please enter 2 strings\n"); scanf("%s %s", input_1, input_2); len_1 = strlen(input_1); len_2 = strlen(input_2); //先筛选调字符串B的重复字符 for (i = 0; i <= len_2 - 1; i++) { for (j = i + 1; j <= len_2 - 1; j++) { if (input_2[i] == input_2[j]) { for (k = j; k <= len_2 - 1; k++) //将这个字符丢掉,将后面的字符向前移动 { input_2[k] = input_2[k + 1]; } len_2--; //字符长度减少 j--; //重新匹对 } } } //字符串A逐个与经过处理的字符串B进行比较,若发现相同的,则剔除 for (i = 0; i <= len_2 - 1; i++) //字符串B { for (j = 0; j <= len_1 - 1; j++) //字符串A { //判断字符串B中的字符是否等于字符串A中的字符,eg:a=a本身;a=A+32;A=a-32 if ((input_2[i] == input_1[j] + 32) || (input_2[i] == input_1[j]) || (input_2[i] == input_1[j] - 32)) { for (k = j; k <= len_1 - 1; k++) //将这个字符丢掉,将后面的字符向前移动 { input_1[k] = input_1[k + 1]; } len_1--; //字符长度减少 j--; //重新匹对 } } } printf("Removing duplicate characters:%s\n", input_1); return 0; }