题解 | #图片整理#

图片整理

https://www.nowcoder.com/practice/2de4127fda5e46858aa85d254af43941


#include <stdio.h>


//思路1:用映射表保存次数,只遍历一遍 0:48,9:57 A:65 Z:90 a:97 z:122
#include <string.h>
#include <stdlib.h>
#define SIZE 123
int* StrToMap(char* str) {

    int* map = (int*)malloc(SIZE * sizeof(int));
    memset(map, 256, SIZE * sizeof(int));
    //发现只有前40个map[i]被赋值为了0
    // for(int i=0;i<SIZE;i++)
    // {
    //     printf("%d ",map[i]);
    // }
    //memset中值以 int 形式传递,但是函数在填充内存块时是使用该值的无符号字符形式。
    //意思也就是每个填充8位,总共填充了123个字节,这样也就是40个int表现为0,第41个的后3个字节也被赋值为0
    //所以想要赋值给所有123个int型,需要*sizeof(int),这样就能全部附上0,不过这种方法仅限于,赋值每个字节都是一样的int,赋值1的话都会是0x01010101
    //而且传256也是相当于传0
    int length = strlen(str);
    for (int i = 0; i < length; i++) {
        map[(int)str[i]]++;
    }
    return map;
}




int main() {
    char str[1001] = "gf98739lfvrj8v0u0";
    scanf("%s", str);
    int* map = StrToMap(str);
    for (int i = 0; i < SIZE; i++) {
        while (map[i]-- != 0) {
            printf("%c", i);
        }
    }
    return 0;
}

全部评论

相关推荐

object3:开始给部分🌸孝子上人生第一课了
点赞 评论 收藏
分享
不愿透露姓名的神秘牛友
11-27 10:52
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务