weixin_42737103 2018-07-25 05:58 采纳率: 80%
浏览 934
已采纳

leetcode 383赎金信 C语言

public class Solution {
public boolean canConstruct(String ransomNote, String magazine) {
if (ransomNote == null || magazine == null) {
return false;
}

    int[] index = new int[26];
    for (int i = 0; i < magazine.length(); i++) {
        index[magazine.charAt(i) - 'a']++;
    }
    for (int j = 0; j < ransomNote.length(); j++) {
        if (--index[ransomNote.charAt(j) - 'a'] < 0) {
            return false;
        }
    }

    return true;
}

}

在网上看到了这个答案,请问第九行也就是 index[magazine.charAt(i) - 'a']++;用C语言该如何实现呢?

  • 写回答

4条回答 默认 最新

  • vinacky 2018-07-25 08:02
    关注

    看到这个问题,顺手做了一下这道题,写了一个C语言版的答案,写了详细的思路说明。思路和题主代码完全一样。
    https://blog.csdn.net/vinacky/article/details/81204348
    针对题主的问题,index[magazine.charAt(i) - 'a']++;所做的事情就是,magazine.charAt(i)是对magazine字符串取出第i个字符,此时是字符表示,对应数字就是ascii码,减去‘a’这个字符,得到的就是在小写字母中的第几个。
    index数组中保存magazine字符串各个字母有多少个。
    如果写成C语言就是index[magazine[i]-'a']++;

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(3条)

报告相同问题?

悬赏问题

  • ¥15 累加器设初值为00H
  • ¥15 webAPI接口返回值判断
  • ¥15 自动化测试 UI Automtion
  • ¥20 关于#深度学习#的问题:2708)输出:邻接矩阵A 或者 节点索引方式:通过随机游走或者其他方式,保持节点连接类似下图(语言-python)
  • ¥15 win2012 iscsi ipsec
  • ¥15 封装的 matplotlib animation 不显示图像
  • ¥15 python摄像头画面无法显示
  • ¥15 关于#3d#的问题:d标定算法(语言-python)
  • ¥15 cve,cnnvd漏洞扫描工具推荐
  • ¥15 图像超分real-esrgan网络自己训练模型遇到问题