字符串与数组

字符串与数组

1. 数组重复元素

数组 a[N] 中存放了 1 至 N - 1 个数,其中某个数重复了一次。求找出重复元素,时间复杂度必须为 O(N)。


  • 异或法
  • 和差法
  • 哈希表

参考:数组重复元素求值

2. 简述数组和指针的区别

指针 数组
保存数据的地址 保存数据
间接访问数据 直接访问数据
通常用于动态数据结构 通常用于存储固定数目类型相同的元素
相关操作 new,delete 等 隐式分配和删除

还要提醒一点的就是:

char a[] = "abcdefg";  //数组内容能修改(字符数组)
char *p = "abcdefg";  //内容不能修改(字符串常量)

在 C/C++ 中,初始化指针时所创建的字符串,被定义为只读

3. 数组的偏移

运行下面程序,求输出结果?

#include <iostream>

using namespace std;

int main()
{
    int a[5] = {1, 2, 3, 4, 5};
    int* ptr = (int*)(&a + 1);
    cout << *(a + 1) << ", " << *(ptr - 1);
    return 0;
} 

输出结果为:2, 5

本题考察的是 a 与 &a 的区别。

&a+1 不是 首地址+1, 系统会认为加上了一个 a[ ] 的偏移,是偏移了一个数组的大小。因为 &a 是数组指针,其类型为 int(*)[5];而 指针+1 要根据指针类型加上一定的值,不同类型的指针+1 之后增加的大小不同。

a 是长度为 5 的 int 数组指针,所以要加 5 * sizeof(int) ,ptr 实际上是 a[5] 。但是 ptr 和 (&a + 1) 类型不一样,所以 ptr - 1 只会减去 sizeof(int*) 。

a,&a 的地址是一样的,但意义不同,&a 是对象(数组)首地址,a 是数组首地址,也就是 a[0] 的地址,a + 1 是数组下一元素的地址,即 a[1] ,故输出结果为 2 ;&a + 1 是下一个对象的地址,即 a[5] ,所以 ptr - 1
的值为 a[4] ,故输出结果为 5 。

4. 多维数组的输出

int a[2][2][3] = {{{1, 6, 3}, {5, 4, 15}}, {{3, 5, 33}, {23, 12, 7}}};
for (int i = 0; i < 12; i++)
    cout << ______ << endl;

在空格处填上合适的语句,顺序打印出 a 中的数字。


a[i / 6][(i / 3) % 2][i % 3]

第一维,前六次循环都取 0 ,后六次都取 1 ,于是 i / 6 可以满足要求;第二维,前三次取 0 ,再三次取 1 ,再三次取 0 ,再三次取 1 ,用量化的思想,i /3 把 12 个数字分为 4 组,每组 3 个,量化为 0、1、2、3,为了得到 0、1、0、1,这里需要取余,于是有 (i / 3) % 2 ;第三维需要(0、1、2;0、1、2;0、1、2;0、1、2),于是有 i % 3 。

5. 字符数组的输入

输入 5 个国家的英文名字,找到并输出英文名字的首字母按字母顺序排在最前面的那个国家的名字。


#include <iostream>
#include <cstring>

using namespace std;

int main()
{
    char a[5][30];
    char c[30];
    int i;
    for (i = 0; i < 5; i++)
        cin.getline(a[i], 30, '\n');
    strcpy(c, a[0]); 
    for (i = 5; i > 1; i--)
        if(strcmp(c, a[i]) > 0)
            strcpy(c, a[i]);
    cout << c << endl;
    return 0;
}

6. 字符串相关函数

  • strcpy(a, b):把 b 中的字符串复制到 a 中
    注意:
    (1)a 的长度必须大于等于 b;
    (2)a 必须是数组名,b 可以是数组名也可以是字符串;
    (3)复制操作执行内容包括 '\0' ;
    (4)复制操作可以复制部分数组长度(例如:strcpy(a, b[1], 5))。
  • strcmp(a, b):比较 a,b 字符串中对应的字符
    注意:
    (1)若参数 a 和 b 字符串相同则返回 0 ; a 若大于 b 则返回大于 0 的值;a 若小于 b 则返回小于 0 的值;
    (2)区分大小写。
  • strcat(a, b):把 b 字符串连接到 a 后面
    注意:
    (1)a 数组必须要足够大,至少满足同时容纳两个字符串的长度;
    (2)连接操作时,a 数组原有的 '\0' 被删除。
  • strlen:长度计算操作
  • strlwr:大写变小写
  • strupr:小写变大写

7. strcpy 函数和 memcpy 函数有什么区别?它们各自使用时应该注意什么问题?

  • 区别:strcpy 函数操作的对象是字符串,完成从源字符串到目的字符串的复制功能;memcpy 函数顾名思义就是内存复制,实现将一个内存块的内容复制到另一个内存块的功能。
  • 要注意的问题:对于字符串复制来说,两者都可以实现;但是对于非字符串类的数据复制来说,就只能用 memcpy 函数了。
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,012评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,628评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,653评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,485评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,574评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,590评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,596评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,340评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,794评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,102评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,276评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,940评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,583评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,201评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,441评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,173评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,136评论 2 352

推荐阅读更多精彩内容