C语言 校门外的树
题目描述某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米。我们可以把马路看成一个数轴,马路的一端在数轴0的位置,另一端在L的位置;数轴上的每个整数点,...
题目描述
某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米。我们可以把马路看成一个数轴,马路的一端在数轴0的位置,另一端在L的位置;数轴上的每个整数点,即0,1,2,……,L,都种有一棵树。由于马路上有一些区域要用来建地铁。这些区域用它们在数轴上的起始点和终止点表示。已知任一区域的起始点和终止点的坐标都是整数,区域之间可能有重合的部分。现在要把这些区域中的树(包括区域端点处的两棵树)移走。你的任务是计算将这些树都移走后,马路上还有多少棵树。
输入
输入第一行有两个整数L(1 <= L <= 10000)和 M(1 <= M <= 100),L代表马路的长度,M代表区域的数目,L和M之间用一个空格隔开。接下来的M行每行包含两个不同的整数,用一个空格隔开,表示一个区域的起始点和终止点的坐标。
输出
输出包括一行,这一行只包含一个整数,表示马路上剩余的树的数目。
样例输入
500 3
150 300
100 200
470 471
样例输出
298
下面是自己写的代码,按给的输入数据却得不到正确的结果,思路啥的按说都比较清晰啊。。。求指教:
#include<stdio.h>
#include<stdlib.h>
#define maxn 100
int main(){
int i,j,k,m,total;
int t_length;
int begin[maxn],over[maxn],length[maxn];
total=0;
scanf("%d %d",&t_length,&j);
if((t_length>=1&&t_length<=10000)&&(j>=1&&j<=100)){
for(i=0;i<j;i++)
scanf("%d %d",&begin[i],&over[i]);
length[i]=(over[i]-begin[i]);
for(m=0;m<j-1;m++)
for(k=m+1;k<j;k++){
//判断是否有重叠部分,有的话重新取边界,并且将“小”的部分却除
if((begin[m]<=over[k])&&(over[m]>=begin[k]))
{over[m]=((over[m]>over[k])?over[m]:over[k]);
begin[m]=((begin[m]<begin[j])?begin[m]:begin[j]);
begin[k]=over[k]=0;
}
}
for(i=0;i<j;i++)
{
length[i]=(over[i]-begin[i]);
total+=length[i];
}
printf("%d",t_length-total);
}
system("pause");
return 0;
}
有三目运算符的两行的功能无法实现。。。 展开
某校大门外长度为L的马路上有一排树,每两棵相邻的树之间的间隔都是1米。我们可以把马路看成一个数轴,马路的一端在数轴0的位置,另一端在L的位置;数轴上的每个整数点,即0,1,2,……,L,都种有一棵树。由于马路上有一些区域要用来建地铁。这些区域用它们在数轴上的起始点和终止点表示。已知任一区域的起始点和终止点的坐标都是整数,区域之间可能有重合的部分。现在要把这些区域中的树(包括区域端点处的两棵树)移走。你的任务是计算将这些树都移走后,马路上还有多少棵树。
输入
输入第一行有两个整数L(1 <= L <= 10000)和 M(1 <= M <= 100),L代表马路的长度,M代表区域的数目,L和M之间用一个空格隔开。接下来的M行每行包含两个不同的整数,用一个空格隔开,表示一个区域的起始点和终止点的坐标。
输出
输出包括一行,这一行只包含一个整数,表示马路上剩余的树的数目。
样例输入
500 3
150 300
100 200
470 471
样例输出
298
下面是自己写的代码,按给的输入数据却得不到正确的结果,思路啥的按说都比较清晰啊。。。求指教:
#include<stdio.h>
#include<stdlib.h>
#define maxn 100
int main(){
int i,j,k,m,total;
int t_length;
int begin[maxn],over[maxn],length[maxn];
total=0;
scanf("%d %d",&t_length,&j);
if((t_length>=1&&t_length<=10000)&&(j>=1&&j<=100)){
for(i=0;i<j;i++)
scanf("%d %d",&begin[i],&over[i]);
length[i]=(over[i]-begin[i]);
for(m=0;m<j-1;m++)
for(k=m+1;k<j;k++){
//判断是否有重叠部分,有的话重新取边界,并且将“小”的部分却除
if((begin[m]<=over[k])&&(over[m]>=begin[k]))
{over[m]=((over[m]>over[k])?over[m]:over[k]);
begin[m]=((begin[m]<begin[j])?begin[m]:begin[j]);
begin[k]=over[k]=0;
}
}
for(i=0;i<j;i++)
{
length[i]=(over[i]-begin[i]);
total+=length[i];
}
printf("%d",t_length-total);
}
system("pause");
return 0;
}
有三目运算符的两行的功能无法实现。。。 展开
5个回答
展开全部
#include <stdio.h>
int main()
{
int i,l,n,start,end,sum,a[10000]={0};
scanf("%d %d",&l,&n);
while(n--)
{
scanf("%d%d",&start,&end);
for(i=start;i<=end;i++)
a[i]=1;
}
for(i=0,sum=0;i<=l;i++)
if(a[i]==0)
sum++;
printf("%d\n",sum);
return 0;
}
直接给个代码吧 楼主写得比较复杂
int main()
{
int i,l,n,start,end,sum,a[10000]={0};
scanf("%d %d",&l,&n);
while(n--)
{
scanf("%d%d",&start,&end);
for(i=start;i<=end;i++)
a[i]=1;
}
for(i=0,sum=0;i<=l;i++)
if(a[i]==0)
sum++;
printf("%d\n",sum);
return 0;
}
直接给个代码吧 楼主写得比较复杂
本回答被网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
#include<stdio.h>
#include<string.h>
int main()
{
int m,n,l,k;
int a[10005];
scanf("%d%d",&m,&n);
memset(a,0,sizeof(a));
while(n--)
{
scanf("%d%d",&l,&k);
for(int i=l; i<=k; i++)
{
a[i]=1;
}
}
int count=0;
for(int j=0; j<=m; j++)
{
if(a[j]==0)
count++;
}
printf("%d\n",count);
return 0;
}
#include<string.h>
int main()
{
int m,n,l,k;
int a[10005];
scanf("%d%d",&m,&n);
memset(a,0,sizeof(a));
while(n--)
{
scanf("%d%d",&l,&k);
for(int i=l; i<=k; i++)
{
a[i]=1;
}
}
int count=0;
for(int j=0; j<=m; j++)
{
if(a[j]==0)
count++;
}
printf("%d\n",count);
return 0;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
#include<bits/stdc++.h>
using namespace std;
//bool tree[10002];
int main()
{
int l,m,ans=0,j;//L代表马路的长度,M代表区域的数目,答案
int m1,m2;//表示一个区域的起始点和终止点的坐标
cin>>l>>m;
//运树ing
for(int i=0;i<=l;i++)
tree[i]=1;//1:有树,0:没树,注意:马路长度为l,树有l+1棵
for (m=m-1;m>=0;m--)//每个区域要运走树
{
cin>>m1>>m2;
for (int i=m1;i<=m2;i++)//每个区域内包含树木的多少
{
tree[i]=0;//没树了
}
}
//统计剩下的树
for (int i=l;i>=0;i--)
{
if (tree[i]==1)
ans++;
}
cout<<ans;
return 0;
}
using namespace std;
//bool tree[10002];
int main()
{
int l,m,ans=0,j;//L代表马路的长度,M代表区域的数目,答案
int m1,m2;//表示一个区域的起始点和终止点的坐标
cin>>l>>m;
//运树ing
for(int i=0;i<=l;i++)
tree[i]=1;//1:有树,0:没树,注意:马路长度为l,树有l+1棵
for (m=m-1;m>=0;m--)//每个区域要运走树
{
cin>>m1>>m2;
for (int i=m1;i<=m2;i++)//每个区域内包含树木的多少
{
tree[i]=0;//没树了
}
}
//统计剩下的树
for (int i=l;i>=0;i--)
{
if (tree[i]==1)
ans++;
}
cout<<ans;
return 0;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
飘过........~~~~~~现在还看不懂
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询