字符下标计数

下标计数

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

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.hqwc.cn/news/448443.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

移动端常见布局

单独移动端页面&#xff08;主流&#xff09; 1&#xff0c;流式布局&#xff08;百分比布局&#xff09; 流式布局&#xff0c;就是百分比布局&#xff0c;也称非固定像素布局 通过盒子的宽度设置成百分比来根据屏幕的宽度来进行伸缩&#xff0c;不受固定像素的限制&#x…

Flink实战四_TableAPISQL

接上文&#xff1a;Flink实战三_时间语义 1、Table API和SQL是什么&#xff1f; 接下来理解下Flink的整个客户端API体系&#xff0c;Flink为流式/批量处理应用程序提供了不同级别的抽象&#xff1a; 这四层API是一个依次向上支撑的关系。 Flink API 最底层的抽象就是有状态实…

专业数据治理:数据中台系统塑造企业未来的数字化运营管理新秩序

随着信息化进程的快速推进&#xff0c;数据已然成为企业最为宝贵的资产。对于众多企业而言&#xff0c;如何有效整合、治理以及充分利用这些数据&#xff0c;使之成为推动业务发展的引擎&#xff0c;成为当前难题。数据中台应运而生&#xff0c;它被认为是企业数字化转型的至关…

Ubuntu22.04安装docker

君衍. 一、认识docker二、查看Docker的依赖三、在Ubuntu22.04上安装Docker步骤1、更新Ubuntu2、添加Docker库3、安装Docker4、Docker测试 四、安装docker-compose 一、认识docker Docker是一个软件容器平台&#xff0c;属于Linux容器的一种封装&#xff0c;同时提供简单易用的…

【异常检测复现】【DeSTSeg】在虚拟环境中完成配置

文章目录 1.在虚拟环境中安装git2.更改虚拟环境中包的安装位置3.安装anomalib4.安装虚拟环境5.根据requirements.txt安装包6.选择所建立的虚拟环境&#xff0c;并设置解释器7.查看文件夹的内容8.下载数据集9.引用 记录复现过程中安装各种包的命令 下载数据集到本地 1.在虚拟环境…

低代码助力ERP开发:实现负担得起、灵活与高效的解决方案

企业资源规划工具或 ERP 不再为大型国际企业所保留。如今&#xff0c;从 SME 到大型企业&#xff0c;各种规模的企业都使用 ERP 软件来管理其核心流程。全球ERP 软件市场每年价值超过 250 亿美元&#xff0c;年增长率为 10% 到 20%。如此巨大增长的原因是什么&#xff1f; 传统…

RHEL 9上创建本地Yum/DNF存储库

1.挂载RHEL9 ISO文件或DVD 我们假设RHEL 9 iso文件已经复制到系统中。运行以下mount 命令将 ISO文件挂载到/var/repo文件夹。 $ sudo mkdir /var/repo $ sudo mount -o loop rhel-baseos-9.0-x86_64-dvd.iso /var/repo/ 如果是 DVD&#xff0c;请运行 $ sudo mount /dev/sr0 …

LeetCode 每日一题Day 54 - 61

2859. 计算 K 置位下标对应元素的和 给你一个下标从 0 开始的整数数组 nums 和一个整数 k 。 请你用整数形式返回 nums 中的特定元素之 和 &#xff0c;这些特定元素满足&#xff1a;其对应下标的二进制表示中恰存在 k 个置位。 整数的二进制表示中的 1 就是这个整数的 置位…

从零搭建Vue3 + Typescript + Pinia + Vite + Tailwind CSS + Element Plus开发脚手架

项目代码以上传至码云&#xff0c;项目地址&#xff1a;https://gitee.com/breezefaith/vue-ts-scaffold 文章目录 前言脚手架技术栈简介vue3TypeScriptPiniaTailwind CSSElement Plusvite 详细步骤Node.js安装创建以 typescript 开发的vue3工程集成Pinia安装pinia修改main.ts创…

DockerCompose+SpringBoot+Nginx+Mysql实践

DockerComposeSpringBootNginxMysql实践 1、Spring Boot案例 首先我们先准备一个 Spring Boot 使用 Mysql 的小场景&#xff0c;我们做这样一个示例&#xff0c;使用 Spring Boot 做一个 Web 应 用&#xff0c;提供一个按照 IP 地址统计访问次数的方法&#xff0c;每次请求时…

企业中不同大数据迁移的区别是什么?

在大数据时代&#xff0c;企业面临着海量数据的管理、分析和应用挑战。为了克服数据存储、传输和处理中的难题&#xff0c;如数据量巨大、网络环境多变、存储成本高昂以及安全风险上升等&#xff0c;企业必须对数据进行备份、同步、分发或归档。这一过程中&#xff0c;数据的复…

前端换肤的五种思路和优缺点

一、什么是前端换肤 前端换肤是指在前端开发中&#xff0c;通过改变网页的样式来实现不同的主题或皮肤效果。通过换肤&#xff0c;可以改变网页的颜色、字体、背景等样式&#xff0c;以适应不同的用户喜好或实现特定的设计需求。 静态换肤&#xff1a; 是指在网页加载时&…