C# —— 字典

简介

字典: 包含一个key(键)和这个key所对应的value(值),字典是无序的,key是唯一的,可以根据key获取值。可以吧键当成数组的索引值进行理解

<> 泛型

定义一个字典 new Dictionary<key的类型, value值的类型>()

cs 复制代码
var dic = new Dictionary<string, string>();
dic.Add("name", "刘总");// add() 方法添加键值对 键为name值为 值为刘总
dic.Add("age", "20");// 添加一个元素 键为age 值为20

遍历字典

keys 获取字典当中所有的key

dic keys.ToArray() 把所有的key转成数组的结果

cs 复制代码
Console.WriteLine(string.Join(",",dic.Keys.ToArray()));

dic.Values.ToArray() 把所有的值转成数组

cs 复制代码
Console.WriteLine(string.Join(",",dic.Values.ToArray()));

移除字典

dic.Remove("name");//移除制定key的方法

是否包含 key 如果包含了返回true

cs 复制代码
Console.WriteLine(dic.ContainsKey("name")); 

把所有的key转成数组再进行遍历

cs 复制代码
for(int i=0; i < dic.Keys.ToArray().Length;i++)
{
    Console.WriteLine(dic.Keys.ToArray()[i]);
}

获取字典值

cs 复制代码
Console.WriteLine(dic["name"]);

使用字典实现统计元素出现次数以及最大次数

key 是出现元素 如果6

value 存放出现的次数 4次

cs 复制代码
ArrayList aa = new ArrayList() { 1, 1, 1, 2, 2, 3,456, 66, 6, 6, 6, 6, };
var dic1 = new Dictionary<int, int>();//定义一个字典 ,向字典里添加元素和次数

遍历数组 v就是数组的每一个元素

cs 复制代码
foreach (int v in aa)
{
    if (dic1.ContainsKey(v)) // 先判断字典里存在不存在当前key 字典里面已经存在相同的key 值加1
    {
        dic1[v] += 1;
    }
    else // 字典不存在key key存在字典中并且次数为1 给字典添加键值对 键时v值为1
    {
        dic1.Add(v, 1);
    }
}
Console.WriteLine(string.Join(",",dic1.Values.ToArray()));
Console.WriteLine(string.Join(",",dic1.Keys.ToArray()));
int maxV = dic1.Keys.ToArray()[0]; // 初始默认出现元素为数组的索引值为0
int maxCount = dic1.Values.ToArray()[0];//初始化最大次数为values当中第一个

for (int i = 0; i < dic1.Values.Count; i++)
{
    // dic1.Values.ToArray()转成数组
    // [i]数组当中的元素 出现的次数
    if (maxCount <= dic1.Values.ToArray()[i])
    {
        maxCount = dic1.Values.ToArray()[i];
        maxV = dic1.Keys.ToArray()[i];
    }
}
Console.WriteLine(maxV+"出现了,出现了最大次数为:"+maxCount);
相关推荐
njsgcs6 小时前
拆分多实体到装配体 solidworks c#
c#
qeen877 小时前
【数据结构】树的基本概念及存储
c语言·数据结构·c++·学习·
一江寒逸7 小时前
数据结构与算法之美:串(字符串)——从基础操作到KMP模式匹配,吃透面试最高频的字符串考点
数据结构·面试·职场和发展
何以解忧唯有撸码7 小时前
C# 视频录制监控系统
c#·winform
hi_ro_a7 小时前
C++ 哈希表封装 unordered_map /unordered_set
数据结构·c++·算法·哈希算法
Jasmine_llq11 小时前
《B4447 [GESP202512 二级] 环保能量球》
数据结构·算法·数学公式计算(核心)·整数除法算法·多组数据循环处理·输入输出算法·简单模拟算法
菜鸟丁小真12 小时前
LeetCode hot100 -73.矩阵置零
数据结构·leetcode·矩阵·知识点总结
xiaoshuaishuai813 小时前
C# modbustcp的ack包通信延迟原因
网络·tcp/ip·c#
꧁细听勿语情꧂13 小时前
向下调整算法,top - k 问题,链式结构二叉树,前中后序遍历
c语言·开发语言·数据结构·算法
如君愿13 小时前
考研复习 Day 22 | 数据结构与算法--排序(下)
数据结构·考研·排序算法·记录考研