题目:一份购物单(五个货号),去四个不同的商店购物,每个物品有自己的货号。判断哪一家所含要购物品最多如若所含量一样,输出所含一样店家的最后一家。
#include
using namespace std;
int main()
{
int a[5]={0},i,s=0,d=0,f=0,g=0;
for(i=0;i cin>>a[i];
int b[4][5];
int j,k;
for(j=0;j for(k=0;k cin>>b[j][k];
for(int y=0;y<5;y++)
{
if(a[i]==b[0][y])s+=s;
if(a[i]==b[1][y])d+=d;
if(a[i]==b[2][y])f+=f;
if(a[i]==b[3][y])g+=g;
}
cout<<s<<endl;
cout<<d<<endl;
cout<<f<<endl;
cout<<g<<endl;
return 0;
}
不妨使用降维的思想 将二维数组转换为一位数组
#include <iostream>
#include <algorithm>
using namespace std;
int main()
{
int a[6]={0},b[21]={0};//改用一位数组装二维数组的东西
int c[4]={0};//用于存储商家符合货号的个数
for(int i=1;i<=5;i++)
cin>>a[i];
for(int i=1;i<=20;i++)
cin>>b[i];
for(int i=1;i<=5;i++)
{
for(int j=0;j<5;j++)
{
if(a[i]==b[i+5*j])//b[i+5*j]等同于二维数组中的b[i][j]
{
c[j]++;
}
}
}
int max=-1,flagi=-1;
for(int i=0;i<4;i++)
{
cout<<c[i]<<endl;
if(c[i]>=max)
{
flagi=i;
max=c[i];
}
}
cout<<flagi+1<<endl;
}