解题思路:
可以将此题看作一个计数问题,共有L棵树,砍去M个区域中的树,还剩下多少树,所以不妨将每棵树赋值为1,砍去是赋值为0,最后累加1的数量,即可得到正解。
注意事项:
数组的大小要足够大;还有一个小问题,不要忘了if后的条件语句的等式为==(我是这样检查了好几遍才发现问题,希望你们没有这样的粗心问题:)
参考代码:
#include<iostream>
using namespace std;
int main()
{
int a[10000];
int l,m,x,y;
cin>>l>>m;
for(int i=0;i<=l;i++)
a[i]=1;
for(int i=0;i<m;i++)
{
cin>>x>>y;
for(int j=x;j<=y;j++)
a[j]=0;
}
int s=0;
for(int i=0;i<=l;i++)
if(a[i]==1) s=s+1;
cout<<s;
return 0;
}
0.0分
4 人评分
C语言程序设计教程(第三版)课后习题9.4 (Java代码)浏览:1415 |
【亲和数】 (C语言代码)浏览:492 |
不会做的浏览:870 |
C语言训练-大、小写问题 (C语言代码)浏览:724 |
C语言训练-亲密数 (C语言代码)浏览:682 |
核桃的数量 (C语言代码)浏览:668 |
1013题解浏览:552 |
矩形面积交 (C语言代码)浏览:1293 |
生日日数 (C语言代码)浏览:1497 |
C语言程序设计教程(第三版)课后习题8.5 (C语言代码)浏览:549 |