1.输入n个数,统计每个值连续出现多少次
思路:定义一个正在统计的数x和将读入的数y,输入x后进行while(n--)循环,输入y。
若y==x则计数器cnt+1;否则输出前一个值x的个数。再将前一个值x覆盖掉(x = y;).
跳出循环后输出一遍最后一个值的个数(否则结果不统计最后一个数)。再用system函数将程序停止。
#include <iostream>
using namespace std;
int main()
{
int x = 0, y = 0;//x是正在统计的数,y是将读入的新值
int n;
cin >> n;//规定n个数
if (n--)
{
cin >> x;
int cnt = 1;//计数器,保存当前值的个数
while (n--)
{
cin >> y;
if (y == x) cnt++;
else { //否则打印前一个值的个数
cout << x << " occurs " << cnt << " times" << endl;
x = y;//记住新值
cnt = 1;//重置计数器
}
}//while循环结束
cout << x << " occurs " << cnt << " times" << endl;//记住打印最后一个值的个数
}
system("pause");
return 0;
}
结果显示:
2.统计每个单词出现次数
题目:从键盘上输入一些单词(以空格为分隔符,” $$$”为结束标志,最多20个)。然后统计每个单词出现的次数。最后按输入顺序输出各个单词及其对应的出现次数。
输入
以空格分隔的、以"$$$"为结束标志的、数量不超过20个的单词
输出
按输入顺序输出各个单词及其对应的出现次数。输出时,每个单词占一行,单词及其出现次数之间以空格分隔。
样例输入
Girl Boy Girl Student Lin Student $$$
样例输出
Girl 2
Boy 1
Student 2
Lin 1
代码
#include<stdio.h>
#include<string.h>
int main()
{
int i,j,m,b[100]={0};//计数器要初始化,否则系统随意给数
char a[100][100],s[100];//a[]指题中的单词有多少个(列) 第二个[]值每个单词的字母个数
scanf("%s",&a[0]); //s[]即指a[][]中第二个[]
b[0]++;
i=0;
while(strcmp(a[i],"$$$"))//如果单词(a[i])不等于$$$则执行下面程序
{
scanf("%s",s);
for(j=0;j<=i;j++)
{
if(strcmp(a[j],s))//如果a[]不等于该字符串s[],则继续执行
{
if(j==i)//倘若j=i则,表明是数组里面最后一个了。i与j是否相等判断是新的还是旧的 (新旧指之前这个单词有没有出现过)
{
strcpy(a[i+1],s);i++;// 则将此字符串a[]复制到这一行单词s[]中
}
}
else
{
b[j]++;//若是新的就i+1
break;//若符合退出循环
}
}
}
for(m=0;m<i;m++)//做一次循环然后总体输出
{
printf("%s %d\n",a[m],b[m]);
}
return 0;
}
*3.题型:输出不重复的所有单词
1)题目:输入n个整数,输出不重复的所有整数(前提:重复的数是连续的) 和第一题思路相近
#include <iostream> //题目:输入n个整数,输出不重复的所有整数
using namespace std;
int main()
{
int x = 0, y = 0;//x为正在读入的数,y为将要读入的数
int n;
cin >> n;
if (n--)
{
cin >> x;
while (n--)
{
cin >> y;
if (y == x) continue;//continue是结束本次循环
else {
cout << x ;
x = y;
}
}
cout << x ;
}
system("pause");
return 0;
}
2)题目:输入n个整数,输出不重复整数及它们的和 (重复的数字不一定是连续的)
#include<stdio.h>
int main()
{
int a[10],b[10],i=0,j=0,k=0,m=0,sum=0;
char ch;
int flag;
do
{
scanf("%d",&a[i]);
i++;
}
while((ch=getchar())!='\n'); //循环条件:将字符ch赋值所输入的字符a[i],当没输到结尾时
k=i;
for(i=0;i<k;i++)
{
for(j=0;j<k;j++)
{
if((a[i]==a[j])&&(i!=j))
{
flag=1;
break;
}
else if((a[i]==a[j])&&(i==j))
{ flag=0;
break;
}
else //当数不相等时
{flag=0;
}
}
if(flag==0)//即不重复的数字
{
b[m]=a[i]; //将所有不重复数录入到b[]该数组中
m++;
}
}
for(i=0;i<m;i++)
{sum+=b[i];
}
for(i=0;i<m;i++)
{printf("%d ",b[i]);
}
printf("和为:%d",sum);
return 0;
}
4.统计一句话里总共单词个数
题目;输入一行字符,统计其中有多少个单词,单词之间以空格分隔。如果标点符号紧跟在单词之 后, 不单独统计。
输入
一行字符(以空格分隔的多个单词)
输出
一个整数
样例输入
I am a boy.
样例输出
4
思路:遍历数组,根据有多少个空格来间接计算单词个数
代码
#include<stdio.h>
int main(){
char a[50],c;
int i,num=0,word=0; //设num为计数器,word为一标记
gets(a); //输入字符数组
for(int i=0;(c=a[i])!='\0';i++)
{
if(c==' ')word=0; //若输入的为空格,则让word=0
else if(word==0) //当输入不为空格且word=0
{
word=1; //就让word=1
num++; //计数器加一
}
}
printf("%d",num); //输出单词个数
return 0;
}