题解 | #图片整理#

图片整理

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;
}

全部评论

相关推荐

三题看不懂四题不明白二题无法AC&nbsp;T=int(input())&nbsp;for&nbsp;_&nbsp;in&nbsp;range(T):&nbsp;n=int(input())&nbsp;s=input().split()&nbsp;k,mx=1,1&nbsp;for&nbsp;i&nbsp;in&nbsp;range(len(s)-1):&nbsp;if&nbsp;len(s[i])&lt;len(s[i+1]):&nbsp;k+=1&nbsp;elif&nbsp;len(s[i])==len(s[i+1]):&nbsp;if&nbsp;s[i]&lt;=s[i+1]:&nbsp;k+=1&nbsp;...
恭喜臭臭猴子:第二题用栈就行。合法的括号直接出栈了,剩下的是不合法的,肯定都得一个一个走。出入栈的过程中得记下进栈的括号的下标。最后栈里剩下的括号如果相邻两个的下标不连续,说明它们中间有一个合法的括号序列被出栈,结果加一
投递拼多多集团-PDD等公司10个岗位 > 拼多多求职进展汇总 笔试
点赞 评论 收藏
分享
JamesGosling1:同一个公司的实习为什么写三次,就算是不同的小组的话,直接写一段要好点吧
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务