memset()和++b[]是什么意思啊?最好能帮我解释一下这个程序数字的模式是指在一堆给定数字中出现次数最多的数值,如5,5,5,3,3,2,6,4,它的模式就是5.现在你的任务,就是从数字中找到它的模式.(|input_
来源:学生作业帮助网 编辑:作业帮 时间:2024/06/24 01:04:41
![memset()和++b[]是什么意思啊?最好能帮我解释一下这个程序数字的模式是指在一堆给定数字中出现次数最多的数值,如5,5,5,3,3,2,6,4,它的模式就是5.现在你的任务,就是从数字中找到它的模式.(|input_](/uploads/image/z/13350897-9-7.jpg?t=memset%28%29%E5%92%8C%2B%2Bb%5B%5D%E6%98%AF%E4%BB%80%E4%B9%88%E6%84%8F%E6%80%9D%E5%95%8A%3F%E6%9C%80%E5%A5%BD%E8%83%BD%E5%B8%AE%E6%88%91%E8%A7%A3%E9%87%8A%E4%B8%80%E4%B8%8B%E8%BF%99%E4%B8%AA%E7%A8%8B%E5%BA%8F%E6%95%B0%E5%AD%97%E7%9A%84%E6%A8%A1%E5%BC%8F%E6%98%AF%E6%8C%87%E5%9C%A8%E4%B8%80%E5%A0%86%E7%BB%99%E5%AE%9A%E6%95%B0%E5%AD%97%E4%B8%AD%E5%87%BA%E7%8E%B0%E6%AC%A1%E6%95%B0%E6%9C%80%E5%A4%9A%E7%9A%84%E6%95%B0%E5%80%BC%2C%E5%A6%825%2C5%2C5%2C3%2C3%2C2%2C6%2C4%2C%E5%AE%83%E7%9A%84%E6%A8%A1%E5%BC%8F%E5%B0%B1%E6%98%AF5.%E7%8E%B0%E5%9C%A8%E4%BD%A0%E7%9A%84%E4%BB%BB%E5%8A%A1%2C%E5%B0%B1%E6%98%AF%E4%BB%8E%E6%95%B0%E5%AD%97%E4%B8%AD%E6%89%BE%E5%88%B0%E5%AE%83%E7%9A%84%E6%A8%A1%E5%BC%8F.%28%7Cinput_)
memset()和++b[]是什么意思啊?最好能帮我解释一下这个程序数字的模式是指在一堆给定数字中出现次数最多的数值,如5,5,5,3,3,2,6,4,它的模式就是5.现在你的任务,就是从数字中找到它的模式.(|input_
memset()和++b[]是什么意思啊?最好能帮我解释一下这个程序
数字的模式是指在一堆给定数字中出现次数最多的数值,如5,5,5,3,3,2,6,4,它的模式就是5.现在你的任务,就是从数字中找到它的模式.(|input_number|
memset()和++b[]是什么意思啊?最好能帮我解释一下这个程序数字的模式是指在一堆给定数字中出现次数最多的数值,如5,5,5,3,3,2,6,4,它的模式就是5.现在你的任务,就是从数字中找到它的模式.(|input_
哪儿的例子? 申请的b数组浪费了一半!
memset在这里是将b数组全部用0填写一下,避免了对数组的挨个赋值
++b[XX]的含义是对b数组中XX下标的那个数进行++操作,实际就是b[XX]= b[XX]+1
//解释的这部分把原来代码修改了下注意看后面注释
int main(){
int max, max_i;
int n, t, i;
while (scanf("%d", &n) == 1){ // 输入数的个数
memset(b, 0, 2000001); // 初始化b数组,用0填充
while (n-- != 0){
scanf("%d", &t); // 将每个数读入
++b[t]; // 重要点: 输入的数载数组中对应得下标的数值+1,如输入10,则b[10]+1,最后每个数出现的个数就是用作下标时数组b中对应的值
}
max = b[0]; max_i = 0; // 下面的就是遍历所有的,看看哪个出现的次数最多,把它输出出来, 不详说了
for (i=1; i max){
max = b[i]; max_i = i;
}
}
printf("%d\n", max_i);
}
return 0;
}