解题思路:
可以将此题看作一个计数问题,共有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二级辅导-进制转换 (C语言代码)浏览:822 |
C语言训练-8除不尽的数 (C语言代码)暴力解法,答案只有一个,直接输出就好了浏览:1015 |
C语言训练-阶乘和数* (C语言代码)浏览:981 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:520 |
C语言程序设计教程(第三版)课后习题5.6 (C语言代码)浏览:501 |
a+b浏览:432 |
C语言程序设计教程(第三版)课后习题9.10 (C语言代码)浏览:820 |
数对 (C语言代码)浏览:697 |
A+B for Input-Output Practice (VII) (C语言代码)浏览:522 |
DNA (C语言代码)浏览:746 |