问题描述
- 杭电ACM2034代码,老出错。
-
我写的代码哪里有问题呀,改好几遍了。。。
题目地址:http://acm.hdu.edu.cn/showproblem.php?pid=2034
#include
#include
#include
#include
using namespace std;
int main()
{
int n,m;
while(scanf("%d%d",&n,&m))
{
if(n==0&&m==0)
break;
int a[n],b[m];
int count=0;
vector v;
for(int i=0;i<n;i++)
{
scanf("%d",&a[i]);
v.push_back(a[i]);
}
for(int i=0;i<m;i++)
scanf("%d",&b[i]);
for(int i=0;i<n;i++)
{
for(int j=0;j<m;j++)
{
if(a[i]==b[j])
{
v.erase(v.begin()+(i-1));
count++;
}
}
}
if(count==n)
{
printf("NULL
");
}
else
{
sort(v.begin(),v.end());
for(int i=0;i<v.size()-1;i++)
printf("%d ",v[i]);
printf("%d
",v[v.size()]);
}
}
return 0;
}
解决方案
#include<stdio.h>
int main()
{
int n,m,i,j,t,temp;
int a[100];
int b[100];
int c[100];
while(scanf("%d %d",&n,&m)!=EOF)
{
t=0;
if(n==0&&m==0)
break;
for(i=0;i<n;i++)
{
scanf("%d",&a[i]);
}
for(j=0;j<m;j++)
{
scanf("%d",&b[j]);
}
for(i=0;i<n;i++)
{
for(j=0;j<m;j++)
{
if(a[i]==b[j])
break;
}
if(j==m)
{
c[t]=a[i];
t++;
}
}
if(t==0)
printf("NULL
");
else
{
for(j=0;j<t-1;j++)
{
for(i=0;i<t-1-j;i++)
if(c[i]>c[i+1])
{
temp=c[i];
c[i]=c[i+1];
c[i+1]=temp;
}
}
for(i=0;i<t;i++)
{
printf("%d ",c[i]);
if(i!=t-1)
printf(" ");
}
printf("
");
}
}
return 0;
}
解决方案二:
杭电acm--2034
杭电 2034
杭电2034
时间: 2024-11-03 21:18:33