实验9 指针1
2013-11-07 09:24
92 查看
1、程序填空:下列程序在数组中同时查找最大元素和最小元素的下标,分别存放在 main()函数的max 和 min 变量中。要求:根据运行结果分析程序和填空,并注释说明填充依据。
2、输入一行字符,要求用自定义的函数void f(char *line)统计和输出字符串中数字字符、英文字符和其他字符的个数。
程序运行结果
3、编程判断输入的一串字符是否为“回文”。所谓“回文”,是指顺读和倒读都一样的字符串。如“XYZYX”和“xyzzyx”都是“回文”。要求使用指针变量判断字符串是否是回文。
4、输入两个字符串s和t,主函数通过调用(自定义)子函数先将字符串s倒置,然后再连接到字符串t之后。要求子函数的定义为void StrRecCat(char *s,char *t),比如,先将字符串abc倒置、然后接到字符串def之后,输出结果为:defcba。
#include <stdio.h> void findByPoint(int *, int, int *, int *); void find(int *a, int n, int max, int min); int main(void) { int max1=0, min1=0, a[]={5,3,7,9,2,0,4,1,6,8}; findByPoint(a,10,&max1,&min1); //自定义函数,指针变量是a,max,min,地址是&max1 printf("数组a最大和最小元素下标是%d,%d\n", max1, min1); int max2=0, min2=0,b[]={3,4,71,9,2,7,4,2,6,90}; find(b,10,max2,min2); //自定义函数,指针变量是a,max,min,地址是&max2 printf("数组b最大和最小元素下标是%d,%d\n", max2, min2); return 0; } void findByPoint(int *a, int n, int *max, int *min) { int i; *max=*min=0; for (i = 1; i < n; i++) { if (a[i] > a [*max])*max=i; //*max指的是max的值,把i的值给*max if (a[i] < a [*min])*min=i; //同上 } } void find(int *a, int n, int max, int min) { int i; for (i = 1; i < n; i++) { if (a[i] > a [max])max=i; //max是变量,i的值给max if (a[i] < a [min])min=i; //同上 } printf("数组b最大和最小元素下标是%d,%d\n", max, min); }
2、输入一行字符,要求用自定义的函数void f(char *line)统计和输出字符串中数字字符、英文字符和其他字符的个数。
程序运行结果
#include<stdio.h> void count(char*s,int*digit,int*letter,int*other) { *digit=*letter=*other=0; while(*s!='\0'){ if(*s>='0'&&*s<='9') //在0~9之间为数字字符 (*digit)++; else if((*s>='a'&&*s<='z')||(*s>='A'&&*s<='Z')) //在a~z或A~Z为英文字符 (*letter)++; else (*other)++; s++; } } int main() { int i=0,digit,letter,other; char ch,str[80]; printf("Enter charaters:");//输入提示 ch=getchar(); while(ch!='\n'){ str[i]=ch; i++; ch=getchar(); } str[i]='\0'; //将结束符'\0'存入数组 count(str,&digit,&letter,&other); //统计字符串中各字符的个数 printf("digit=%d letter=%d other=%d\n",digit,letter,other); //输出字符个数 return 0; }
3、编程判断输入的一串字符是否为“回文”。所谓“回文”,是指顺读和倒读都一样的字符串。如“XYZYX”和“xyzzyx”都是“回文”。要求使用指针变量判断字符串是否是回文。
#include<stdio.h> #include<string.h> void main() { char s[20]; char*p,*q; int len,flag; gets(s); len =strlen(s); p=s; q=s+len-1; flag=1; while(p<q) { if(*p==q*){ p++;q--; } else{ flag=0;break; } } if(flag)printf("YES\n"); else printf("No\n"); }
4、输入两个字符串s和t,主函数通过调用(自定义)子函数先将字符串s倒置,然后再连接到字符串t之后。要求子函数的定义为void StrRecCat(char *s,char *t),比如,先将字符串abc倒置、然后接到字符串def之后,输出结果为:defcba。
相关文章推荐
- Populating Next Right Pointers in Each Node [LeetCode]
- 去掉html标签和空格等
- [LeetCode] Path Sum II
- Scanner读取文件输入
- 学习笔记
- Socket封装(31)
- 学习VS2010 -------- 桌面信息提示信息编程
- JBoss 系列四十五:jBPM5示例之 Global Variable
- cookie 记住密码
- 寻人启事:写得一手好代码的你在哪里?
- f# mathprovider
- Oracle data buffer写入原理详解
- UVA 10105 Polynomial Coefficients(数论)
- 网页防止tab键的使用快速解决方法
- yii之登录表单
- EventLoopThread (30)
- EventLoop再分析之IO线程(29)
- 韩顺平js第十八讲
- 2014找工作总结-机会往往留给有准备的人
- 寻找第K小元素