每日一练DAY_25_9

简介: 每日一练DAY_25_9

选择题:

知识点:

char acX[]="abc"与char* szX="abc"的区别:

前者将'a''b''c''\0'存储在数组acX里,数组内容可以改变

后者szX是一个指针,指向常量字符串"abc",指向内容不能改变

char*szX="abc"         char*szY="abc"         szX==szY

字符与数字间的关系

char a[]里存了n个大写字母,

count是一个数组,count[‘Z’-a[i]],如何理解?a[i]代表某个字母,'Z'-a[i]即这个字母与'Z'的相对距离,这个相对距离就是这个字母在count数组中的下标。例如'Z'-'Z'=0,0就是'Z'在count数组中的下标。这是一种映射关系,而不是说'Z'真的存在了count[0]中。 055efc5268304816bbb7f79658799040.png

所以count从0-25存储的分别是从Z-A的出现次数

'Z'-i,什么意思?字符-数字,可以表示字符‘Z’-0=Z,'Z'-1=Y....

以上可以看出:

字符-字符得到 数字(字符间的相对距离)

字符-数字得到字符

小总结一下:字符与数字的转换有一个ASCII码表,是一个数字、字符相互映射的表,比如字符'A'的10进制是65,因而字符间相减的时候其实是他们所对应的10进制数字在相减,综上,字符间的运算最终是其所映射的数字间的运算。

编程:

数组个数与数组下标的关系

     vector<int> v;

   v.resize(n+1);

     while (i < n && v[i] <= v[i + 1])

           {

               ++i;

           }

由于涉及到首元素和后一个元素的比较,即a[i]与a[i+1]的比较,那么当i到了最后一个元素时,就会有越界问题。解决方法:给数组开n+1个空间,并且a[n]=0;

相关文章
|
6月前
|
算法
|
C++
C/C++每日一练(20230412)
C/C++每日一练(20230412)
91 0
|
机器人 C++
C/C++每日一练(20230419)
C/C++每日一练(20230419)
69 0
|
算法 C++
C/C++每日一练(20230425)
C/C++每日一练(20230425)
46 0
|
C++
C/C++每日一练(20230426)
C/C++每日一练(20230426)
61 0
|
存储 C++
C/C++每日一练(20230417)
C/C++每日一练(20230417)
76 0
|
C++
C/C++每日一练(20230331)
C/C++每日一练(20230331)
68 0
|
机器学习/深度学习 C++
C/C++每日一练(20230402)
C/C++每日一练(20230402)
155 0