字符下标计数

news2024/11/16 7:24:48
下标计数

数组计数,即通过使用一个新的数组,对原来数组里面的项进行计数,统计原来数组中各项出现的次数,如下图所示:

1.png

数组计数可以方便快速地统计出一个各项都比较小的数组中,数值相同的数的个数。

 

数组计数常用代码:

2.png

 

   统计数组中0-9的个数 查看测评数据信息

输入n个10以内的正整数,统计其中0-9的个数。

输入格式

两行

第一行:一个整数n,1<=n<=100

第二行:n个整数,范围在[0,9]

输出格式

10行,每行两个数a,b,用空格隔开,a表示数字,b表示对应数字的个数

分别输出0-9每一个数字出现的次数

输入/输出例子1

输入:

5

2 4 6 2 5

输出:

0 0

1 0

2 2

3 0

4 1

5 1

6 1

7 0

8 0

9 0

#include<bits/stdc++.h>
using namespace std;
int main(){
    int n,a[99999],s[99999];
    cin>>n;
    for(int i=1;i<=n;i++){
        cin>>a[i];
    }
    for(int i=1;i<=n;i++){
        if(a[i]==0)s[0]++;
        if(a[i]==1)s[1]++;
        if(a[i]==2)s[2]++;
        if(a[i]==3)s[3]++;
        if(a[i]==4)s[4]++;
        if(a[i]==5)s[5]++;
        if(a[i]==6)s[6]++;
        if(a[i]==7)s[7]++;
        if(a[i]==8)s[8]++;
        if(a[i]==9)s[9]++;       
    }
    for(int i=0;i<=9;i++){
        cout<<i<<" "<<s[i]<<endl;
    }
    return 0;
}

美人松的高度1 查看测评数据信息

又到过年了,狗熊岭的动物们都忙碌了起来,张灯结彩准备过年。李老板却要光头强砍一些百年美人松回去。现在光头强看到丛林里有N棵美人松,当然每棵松的高度是已知的。李老板要问光头强:高度为K的美人松有多少棵?

输入格式

第一行一个正整数N, 1<=N<=1000000。
第二行N个正整数,之间用一个空格隔开,表示N棵美人松的高度,1<=高度<=1000000。
第三行一个正整数K,表示询问高度为K的美人松有多少棵 。

输出格式

一行一个整数,表示对应高度为K的树的数量,如果没有则输出0

输入/输出例子1

输入:

5
3 4 5 2 3
3

输出:

2

#include<bits/stdc++.h>
using namespace std;
int a[1000000],n,m,s;
int main()
{
	scanf("%d",&n);
	for(int i=0;i<n;i++)
	scanf("%d",&a[i]);
	scanf("%d",&m);
	for(int i=0;i<n;i++)
	{
		if(a[i]==m)
		s++;
	}
	printf("%d",s);
	return 0;
 } 
美人松高度2 查看测评数据信息

又到过年了,狗熊岭的动物们都忙碌起来,张灯结彩准备过年。李老板却要光头强砍掉一些百年美人松回去。现在光头强看到丛林里有N颗美人松按照从矮到高排好了,当然每棵松的高度都是已知的。李老板要问光头强M次:每次询问高度为K的美人松的数量

输入格式

第一行,两个正整数N,M,1<=N<=10^6,1<=M<=10^3;
第二行,N个正整数,之间用一个空格隔开,表示N棵美人松的高度,1<=高度<=10000000
第三行M个正整数k,表示M个询问,每次询问高度为K的美人松的数量,1<=k<=1000。

输出格式

一行M个正整数,之间用一个空格隔开,分别表示对应每次询问高度为K的树的查询结果,如果存在,则高度为K的树的数量,不存在则输出0

输入/输出例子1

输入:

5 2

2 3 3 4 5

3 4

输出:

2 1

#include<bits/stdc++.h>
using namespace std;
int  a[10000001],n,m,k,x; 
int main()
{
	scanf("%d%d",&n,&m);
	for(int i=1;i<=n;i++)
	{
	scanf("%d",&k);
	a[k]=a[k]+1;
	}
	for(int i=1;i<=m;i++)
	{
		scanf("%d",&x);
		printf("%d ",a[x]);
	}
	return 0;
 } 
校门外的树 查看测评数据信息

某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米。我们可以把马路看成一个数轴,马路的一端在数轴0的位置,另一端在L的位置;数轴上的每个整数点,即0,1,2,……,L,都种有一棵树。

由于马路上有一些区域要用来建地铁。这些区域用它们在数轴上的起始点和终止点表示。已知任一区域的起始点和终止点的坐标都是整数,区域之间可能有重合的部分。现在要把这些区域中的树(包括区域端点处的两棵树)移走。你的任务是计算将这些树都移走后,马路上还有多少棵树。

输入格式

第一行有两个整数L(1 ≤ L ≤ 10000)和 M(1 ≤ M ≤ 100),L代表马路的长度,M代表区域的数目,L和M之间用一个空格隔开。接下来的M行每行包含两个不同的整数,用一个空格隔开,表示一个区域的起始点和终止点的坐标。

对于20%的数据,区域之间没有重合的部分;对于其它的数据,区域之间有重合的情况。

输出格式

包括一行,这一行只包含一个整数,表示马路上剩余的树的数目。

输入/输出例子1

输入:

500 3
150 300
100 200
470 471

输出:

298

#include<cstdio>
using namespace std;
int a[10001],n,m,x,y,s=0;
int main()
{
	scanf("%d%d",&n,&m);
	for(int i=0;i<=n;i++) 
	a[i]=1;
	for(int i=1;i<=m;i++)
	{
		scanf("%d%d",&x,&y);
		for(int j=x;j<=y;j++) 
		a[j]=0;
	}
	for(int i=0;i<=n;i++)
	{
	if(a[i]==1) 
	s++;	
	}
	printf("%d",s);
	return 0;
}
统计字符个数 查看测评数据信息

要求输入一任意字符串,输出串中出现的小写字母及其出现次数,按照ASCII码由小到大排序输出

输入格式

一行,一个字符串

输出格式

每个出现的小写字母,以及其出现的次数作为单独的一行,中间用空格隔开。

输入/输出例子1

输入:

you are a student

输出:

a 2

d 1

e 2

n 1

o 1

r 1

s 1

t 2

u 2

y 1

#include<bits/stdc++.h>
using namespace std;
int s[26];
char s1[26];
int main(){
    string a;
    getline(cin,a);   
    for(int i=0;i<a.size();i++){
        if(a[i]=='a')s1[0]=a[i],s[0]++;
        if(a[i]=='b')s1[1]=a[i],s[1]++;    
        if(a[i]=='c')s1[2]=a[i],s[2]++;    
        if(a[i]=='d')s1[3]=a[i],s[3]++;    
        if(a[i]=='e')s1[4]=a[i],s[4]++;    
        if(a[i]=='f')s1[5]=a[i],s[5]++;    
        if(a[i]=='g')s1[6]=a[i],s[6]++;    
        if(a[i]=='h')s1[7]=a[i],s[7]++;    
        if(a[i]=='i')s1[8]=a[i],s[8]++;    
        if(a[i]=='j')s1[9]=a[i],s[9]++;    
        if(a[i]=='k')s1[10]=a[i],s[10]++;    
        if(a[i]=='l')s1[11]=a[i],s[11]++;    
        if(a[i]=='m')s1[12]=a[i],s[12]++;    
        if(a[i]=='n')s1[13]=a[i],s[13]++;    
        if(a[i]=='o')s1[14]=a[i],s[14]++;    
        if(a[i]=='p')s1[15]=a[i],s[15]++;    
        if(a[i]=='q')s1[16]=a[i],s[16]++;    
        if(a[i]=='r')s1[17]=a[i],s[17]++;    
        if(a[i]=='s')s1[18]=a[i],s[18]++;    
        if(a[i]=='t')s1[19]=a[i],s[19]++;    
        if(a[i]=='u')s1[20]=a[i],s[20]++;    
        if(a[i]=='v')s1[21]=a[i],s[21]++;    
        if(a[i]=='w')s1[22]=a[i],s[22]++;    
        if(a[i]=='x')s1[23]=a[i],s[23]++;    
        if(a[i]=='y')s1[24]=a[i],s[24]++;    
        if(a[i]=='z')s1[25]=a[i],s[25]++;    
    }
    for(int i=0;i<26;i++){
        if(s[i]!=0)cout<<s1[i]<<" "<<s[i]<<endl;
    }
    return 0;
}
统计字符个数2  查看测评数据信息

要求输入一任意字符串,输出串中出现的小写字母及其出现次数,字符输出顺序按照其在字符串中首次出现顺序排列

输入格式

一行,一个字符串

输出格式

按照其在字符串中首次出现顺序,输出每个出现的小写字母,以及其出现的次数作为单独的一行,中间用空格隔开。

输入/输出例子1

输入:

acbacc

输出:

a 2

c 3

b 1

#include<bits/stdc++.h>
using namespace std;
string s;
int a[26], b[26];
char x[26]={'a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z'}; 
int main () {
getline(cin, s);
for(int i=0; i<s. size (); i++) {
if(s[i]>='a' &&s[i] <= ' z') {
a[(s[i]-'0')-49]++;
}
}
for(int i=0; i<s. size (); i++) {
if(a[(s[i]-'0')-49] != 0&&b[(s[i]-'0')-49] == 0) {
cout << x[(s[i]-'0')-49] << " " << a[(s[i]-'0')-49] << endl;
b[(s[i]-'0')-49]++;
}
}
return 0;
}
只出现一次的字符 查看测评数据信息

给你一个只包含小写字母的字符串;

请你判断是否存在只在字符串中出现过一次的字符;

如果存在,则输出满足条件的字符中,ASCII码最靠前的那个;

如果没有, 输出 no.

输入格式

共一行, 包含一个由小写字母构成的字符串;

数据保证字符串的长度不超过 100000.

输出格式

输出满足条件的第一个字符;

如果没有, 则输出 no.

输入/输出例子1

输入:

you are a student

输出:

d

样例解释

d只出现一次,并且在出现一次的字母中,ASCII码最小

#include<bits/stdc++.h>
using namespace std;
string s;int a[27];
int main(){
getline(cin,s);
for(int i=0;i<s.size();i++)
if(s[i]>='a'&&s[i] <= 'z')
a[s[i]-'a']++;
for(int i=0;i<26;i++)
if(a[i] == 1){
cout << char('a'+i);
return 0;
}
cout << "no";
return 0;
}
统计字符个数3 查看测评数据信息

输入一串字符。对字符中的小写字母进行统计,并按照统计个数由多到少输出,如果统计的个数相同,则按照ASCII码由小到大排序输出 。如果有其他字符,则对这些字符不用进行统计。

输入格式

一行,一个字符串

字符串长度小于1000

输出格式

按照题目要求的顺序输出字符

输入/输出例子1

输入:

aadddccddc

输出:

dca

#include<bits/stdc++.h>
using namespace std;
string s;
int a[30];
int main (){

getline(cin, s);
for(int i=0;i<s.size(); i++)
if(s[i]>='a'&&s[i]<= 'z')
a[s[i]-'a'+1]++;
for(int i=1000;i>=1;i -- )
for(int j=1;j <= 26; j++)
if(a[j]==i)
cout << char('a'+j-1);

return 0;
   }

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1429395.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

PHP集成开发 -- PhpStorm 2023

PhpStorm 2023是一款强大的PHP集成开发环境&#xff08;IDE&#xff09;&#xff0c;旨在提高开发人员的生产力和代码质量。以下是关于PhpStorm 2023软件的详细介绍&#xff1a; 首先&#xff0c;PhpStorm 2023提供了丰富的代码编辑功能&#xff0c;包括语法高亮、自动补全、代…

ubuntu22.04 安装部署01:禁用内核更新

一、前言 ubunut22.04系统安装以后&#xff0c;内核更新会导致各种各样的问题&#xff0c;因此锁定初始安装环境特别重要&#xff0c;下面介绍如何锁定内核更新。 二、操作方法 2.1 查看可用内核 dpkg --list | grep linux-image dpkg --list | grep linux-headers dpkg --…

故障诊断 | 一文解决,CNN-LSTM卷积神经网络-长短期记忆神经网络组合模型的故障诊断(Matlab)

效果一览 文章概述 故障诊断 | 一文解决,CNN-LSTM卷积神经网络-长短期记忆神经网络组合模型的故障诊断(Matlab) 模型描述 CNN-LSTM模型是一种结合了卷积神经网络(Convolutional Neural Network)和长短期记忆神经网络(Long Short-Term Memory)的组合模型,常用于数据故障…

各版本的Qt Creator的下载地址

2024年2月3日&#xff0c;周六上午 Index of /official_releases/qtcreatorhttps://download.qt.io/official_releases/qtcreator/ 如果想下载测试中的最新版Qt Creator的快照可以去这个地址 Index of /snapshots/qtcreatorhttps://download.qt.io/snapshots/qtcreator/

景联文科技受邀出席全国信标委生物特征识别分委会二届五次全会

全国信息技术标准化技术委员会生物特征识别分技术委员会&#xff08;SAC/TC28/SC37&#xff0c;以下简称“分委会”&#xff09;二届五次全会于2024年1月30日在北京顺利召开&#xff0c;会议由分委员秘书长王文峰主持。 分委会由国家标准化管理委员会批准成立&#xff0c;主要负…

git 如何修改仓库地址

问题背景&#xff1a;组内更换大部门之后&#xff0c;代码仓的地址也迁移了&#xff0c;所以原来的git仓库地址失效了。 虽然重新建一个新的文件夹&#xff0c;再把每个项目都git clone一遍也可以。但是有点繁琐&#xff0c;而且有的项目本地还有已经开发一半的代码&#xff0c…

网络异常案例六_IP冲突

问题现象 同一个局域网下&#xff0c;一个路由器带几十台终端设备&#xff0c;存在终端设备获取到了相同IP的场景。该路由器也是DHCP Server。 有两个设备终端&#xff0c;都显示获取到了192.168.11.177这个ip。 抓包分析 抓包过程中&#xff0c;看到的一些问题。 ps&#x…

三路快排解决TopK问题

前言&#xff1a; 我们首先要明白什么是三路快排&#xff0c;什么是topk问题。 三路快排&#xff1a; 思想&#xff1a; 三路快排就是数组分3块&#xff0c;三个指针&#xff0c;先随机取一个基准值key&#xff0c;然后将数组划分为3个部分&#xff1a; 【小于key】【等于…

客户端和服务端的简介

Client 和 Server 客户端&#xff08;Client&#xff09; 或称用户端&#xff0c;是指与服务器相对应&#xff0c;为客户提供本地服务的程序。除了一些只在本地运行的应用程序之外&#xff0c;一般安装在客户机上&#xff0c;需要与服务端互相配合运行。例如&#xff1a;下载 Q…

决策树的相关知识点

&#x1f4d5;参考&#xff1a;ysu老师课件西瓜书 1.决策树的基本概念 【决策树】&#xff1a;决策树是一种描述对样本数据进行分类的树形结构模型&#xff0c;由节点和有向边组成。其中每个内部节点表示一个属性上的判断&#xff0c;每个分支代表一个判断结果的输出&#xff…

爬虫笔记(三):实战qq登录

咳咳&#xff0c;再这样下去会进橘子叭hhhhhh 以及&#xff0c;这个我觉得大概率是成功的&#xff0c;因为测试了太多次&#xff0c;登录并且验证之后&#xff0c;qq提醒我要我修改密码才可以登录捏QAQ 1. selenium 有关selenium具体是啥&#xff0c;这里就不再赘述了&#x…

用C++实现一个哈希桶并封装实现 unordered_map 和 unordered_set

目录 哈希桶的实现 封装 unordered_map 和 unordered_set 封装代码 HashTable.h MyUnorderedMap.h MyUnorderedSet.h 哈希桶&#xff0c;又叫开散列法。开散列法又叫链地址法(开链法)&#xff0c;首先对关键码集合用散列函数计算散列地址&#xff0c;具有相同地址的关键码…

spring问题点

1.事务 1.1.事务传播 同一个类中 事务A调非事务B B抛异常 AB事务生效&#xff08;具有传播性&#xff09; 同一个类中 事务A调非事务B A抛异常 AB事务生效 也就是主方法加了事务注解 则方法内调用的其他本类方法无需加事务注解&#xff0c; 发生异常时可以保证事务的回滚 最常…

安科瑞消防设备电源监控系统在地铁工程的设计与应用

【摘要】&#xff1a;本文介绍了地铁工程中消防设备电源监控系统设置的必要性及规范求&#xff0c;分析了监控设计方案&#xff0c;提出该系统在地铁工程中的应用要求及建议&#xff0c;以供地铁工程建设参考。消防设备电源监控系统主要针对消防用电设备的电源进行实时的监控&a…

在 Elastic Agent 中为 Logstash 输出配置 SSL/TLS

要将数据从 Elastic Agent 安全地发送到 Logstash&#xff0c;你需要配置传输层安全性 (TLS)。 使用 TLS 可确保你的 Elastic Agent 将加密数据发送到受信任的 Logstash 服务器&#xff0c;并且你的 Logstash 服务器从受信任的 Elastic Agent 客户端接收数据。 先决条件 确保你…

深入理解指针(3)

⽬录 1. 字符指针变量 2. 数组指针变量 3. ⼆维数组传参的本质 4. 函数指针变量 5. 函数指针数组 6. 转移表 1. 字符指针变量 在指针的类型中我们知道有⼀种指针类型为字符指针 char* ; ⼀般使⽤: int main() {char ch w;char *pc &ch;*pc w;return 0; } 还有…

面试150 二进制求和 位运算

Problem: 67. 二进制求和 文章目录 思路复杂度Code 思路 &#x1f468;‍&#x1f3eb; 参考 复杂度 时间复杂度: O ( n ) O(n) O(n) 空间复杂度: O ( n ) O(n) O(n) Code class Solution {public String addBinary(String a, String b){StringBuilder ans new Stri…

某赛通电子文档安全管理系统 UploadFileToCatalog SQL注入漏洞复现

0x01 产品简介 某赛通电子文档安全管理系统(简称:CDG)是一款电子文档安全加密软件,该系统利用驱动层透明加密技术,通过对电子文档的加密保护,防止内部员工泄密和外部人员非法窃取企业核心重要数据资产,对电子文档进行全生命周期防护,系统具有透明加密、主动加密、智能…

【类和对象】4

日期类的拓展 c语言中的printf函数只能打印内置类型&#xff0c;为了弥补这一不足&#xff0c;c利用运算符重载可以打印自定义类型。 void operator<<(ostream&out);//声明在date.h中void Date::operator<<(ostream& out)//定义在date.cpp中 {out<<…

C++学习Day01之namespace命名空间

目录 一、程序及输出1.1 命名空间用途&#xff1a; 解决名称冲突1.2 命名空间内容1.3 命名空间必须要声明在全局作用域下1.4 命名空间可以嵌套命名空间1.5 命名空间开放&#xff0c;可以随时给命名空间添加新的成员1.6 命名空间可以是匿名的1.7 命名空间可以起别名 二、分析与总…