指针作业题总结(一) SDUT

2023-10-30 01:08
文章标签 指针 总结 sdut 作业题

本文主要是介绍指针作业题总结(一) SDUT,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在学习指针的过程中,我遇到了很多问题。
指针与数组:
(一)问题:
图一结果正确
图二结果错误
图二犯了一个明显的错误即经过for循环后,m已经指向最后一个元素的地址,因此在输出过程中出现错误。
在第53行加上 m=a;就正确了。

附:数组指针的知识点,仅供参考。

(二)题目
在这里插入图片描述
在这里插入图片描述

该题目为作业题,在做的过程中也出现了许多问题。
在这里,先贴上错误代码(只有字母统计功能):

int tongj(char *arrac,int *numch)
{char* p=arrac;char h='a';int j,i=0,sum=0;int *m=numch;while(*p!='\0'){if(*p<'a')(*p)+=32; //大写转小写p++;}for(j='a';j<='z';j++){for(;*p!='\0';p++){if(*p==j)(*m)+=1;}m++;}for(h='a';h<='z';h++){printf("%c : %d\n",h,*m);m++;}return 1;
}
int main()
{int b[1000]={0};char a[600];scanf("%s",a);printf("Total number of letters \n");tongj(a,b);return 0;
}

运行结果:
统计的字母个数均为0。
问题:
1.大小写转化的条件 if (*p<‘a’) 太广泛,因为 句子中还有空格。
改为:

    while(*p!='\0'){if(*p>='A'&&*p<='Z'){*p+=32;}if(*p>='A'&&*p<='Z'||*p>='a'&&*p<='z')k++;  //统计字母个数p++;}

2.在这里插入图片描述
改为

for(p=arrac;*p!='\0';p++)

原因:不明,想起来再补充。

  1. 在for循环之后,m已经指向最后,因此需要 加上 m=numch;
    我之所以发现了这个问题,是因为我把for循环注释掉了,看剩下程序的运行状况,加了printf,发现并无问题,我在提交的作业上又引入了一个普通的整型变量,使得m的值不变,来完成。

  2. 如果输入的字符中带有空格,如:and jidsshhhh
    那么字符统计的结果是 a:1 n:1 d:1 其余为0
    这里我想了很久,最后我把主函数中的scanf改成了 gets ,成功输出正确结果。
    附:字符数组的输入与输出
    用scanf 输入,printf输出时,%s识别空格作为字符串的结尾,所以第一个空格就是结尾,之后的内容便不会输出。也就是使用%s格式输入并保存到字符数组中的字符串是不含空格的。
    详细内容见上述链接。

在处理完这些问题后,成功!
在这里插入图片描述
最后附上作业代码,增加了百分比

#include <stdio.h>#include <stdlib.h>#include <string.h>int tongj(char *arrac,int *numch){char *p=arrac;char h='a';int j,sum=0,i=0,n=0;int *m=numch;int k=0;while(*p!='\0'){if(*p>='A'&&*p<='Z'){*p+=32;}if(*p>='A'&&*p<='Z'||*p>='a'&&*p<='z')k++;p++;}for(j='a';j<='z';j++){for(p=arrac;*p!='\0';p++){if(*p==j){*(m+n)+=1;sum++;}}n++;}printf("\nTotal number of letters: %d \n",k);for(h='a';h<='z';h++){printf("%c : %d",h,*(m+i));printf("\t\t: %.2f%%\n",(float)*(m+i)/sum*100.0);i++;}return 1;}int main(){int b[600]={0};char a[600];gets(a);tongj(a,b);return 0;}

结果:
在这里插入图片描述
在这里就告一段落。
谢谢。

这篇关于指针作业题总结(一) SDUT的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/304602

相关文章

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert

学习hash总结

2014/1/29/   最近刚开始学hash,名字很陌生,但是hash的思想却很熟悉,以前早就做过此类的题,但是不知道这就是hash思想而已,说白了hash就是一个映射,往往灵活利用数组的下标来实现算法,hash的作用:1、判重;2、统计次数;

git使用的说明总结

Git使用说明 下载安装(下载地址) macOS: Git - Downloading macOS Windows: Git - Downloading Windows Linux/Unix: Git (git-scm.com) 创建新仓库 本地创建新仓库:创建新文件夹,进入文件夹目录,执行指令 git init ,用以创建新的git 克隆仓库 执行指令用以创建一个本地仓库的

二分最大匹配总结

HDU 2444  黑白染色 ,二分图判定 const int maxn = 208 ;vector<int> g[maxn] ;int n ;bool vis[maxn] ;int match[maxn] ;;int color[maxn] ;int setcolor(int u , int c){color[u] = c ;for(vector<int>::iter

整数Hash散列总结

方法:    step1  :线性探测  step2 散列   当 h(k)位置已经存储有元素的时候,依次探查(h(k)+i) mod S, i=1,2,3…,直到找到空的存储单元为止。其中,S为 数组长度。 HDU 1496   a*x1^2+b*x2^2+c*x3^2+d*x4^2=0 。 x在 [-100,100] 解的个数  const int MaxN = 3000

状态dp总结

zoj 3631  N 个数中选若干数和(只能选一次)<=M 的最大值 const int Max_N = 38 ;int a[1<<16] , b[1<<16] , x[Max_N] , e[Max_N] ;void GetNum(int g[] , int n , int s[] , int &m){ int i , j , t ;m = 0 ;for(i = 0 ;

go基础知识归纳总结

无缓冲的 channel 和有缓冲的 channel 的区别? 在 Go 语言中,channel 是用来在 goroutines 之间传递数据的主要机制。它们有两种类型:无缓冲的 channel 和有缓冲的 channel。 无缓冲的 channel 行为:无缓冲的 channel 是一种同步的通信方式,发送和接收必须同时发生。如果一个 goroutine 试图通过无缓冲 channel

【C++学习笔记 20】C++中的智能指针

智能指针的功能 在上一篇笔记提到了在栈和堆上创建变量的区别,使用new关键字创建变量时,需要搭配delete关键字销毁变量。而智能指针的作用就是调用new分配内存时,不必自己去调用delete,甚至不用调用new。 智能指针实际上就是对原始指针的包装。 unique_ptr 最简单的智能指针,是一种作用域指针,意思是当指针超出该作用域时,会自动调用delete。它名为unique的原因是这个

9.8javaweb项目总结

1.主界面用户信息显示 登录成功后,将用户信息存储在记录在 localStorage中,然后进入界面之前通过js来渲染主界面 存储用户信息 将用户信息渲染在主界面上,并且头像设置跳转,到个人资料界面 这里数据库中还没有设置相关信息 2.模糊查找 检测输入框是否有变更,有的话调用方法,进行查找 发送检测请求,然后接收的时候设置最多显示四个类似的搜索结果

C语言指针入门 《C语言非常道》

C语言指针入门 《C语言非常道》 作为一个程序员,我接触 C 语言有十年了。有的朋友让我推荐 C 语言的参考书,我不敢乱推荐,尤其是国内作者写的书,往往七拼八凑,漏洞百出。 但是,李忠老师的《C语言非常道》值得一读。对了,李老师有个官网,网址是: 李忠老师官网 最棒的是,有配套的教学视频,可以试看。 试看点这里 接下来言归正传,讲解指针。以下内容很多都参考了李忠老师的《C语言非