欢迎来到尧图网

客户服务 关于我们

您的位置:首页 > 教育 > 培训 > 2021 CCF 非专业级别软件能力认证第一轮(CSP-J1)入门级C++语言试题 (第三大题:完善程序 代码)

2021 CCF 非专业级别软件能力认证第一轮(CSP-J1)入门级C++语言试题 (第三大题:完善程序 代码)

2024/10/25 9:23:18 来源:https://blog.csdn.net/mmz1207/article/details/141786533  浏览:    关键词:2021 CCF 非专业级别软件能力认证第一轮(CSP-J1)入门级C++语言试题 (第三大题:完善程序 代码)

最近有一段时间没更新了,在准备CSP考试,请大家见谅。

(1)

有n个人围成一个圈,依次标号0到n-1。从0号开始,依次0,1,0,1... 交替报数,报到一的人离开,直至圈中剩最后一个人。求最后剩下的人的编号。

#include <iostream>
using namespace std;int f[1000010];int main()
{int n;cin>>n;int i = 0,cnt = 0,p = 0;while(cnt<n-1){if(f[i]==0){if(p){f[i] = 1;cnt++;}p ^= 1;}i = (i+1)%n;}int ans = -1;for(i = 0;i<n;i++){if(f[i]==0){ans = i;}}cout<<ans<<endl;return 0;
}

(2)

平面上有n个关键点,求有多少个四边形都和x轴或y轴平行的矩形,满足四个顶点都是关键点。给出的关键点可能重复,但完全重合的矩形只计一次。

#include <iostream>
#include <algorithm>
using namespace std;
struct point
{int x,y,id;
};
point a[100];
point b[100];
int n;
int lb = 0;bool cmp(point,point);
bool find(int,int);int main()
{cin>>n;for(int i = 0;i<n;i++){cin>>a[i].x>>a[i].y;a[i].id = i;}sort(a+0,a+n,cmp);for(int i = 0;i<n;i++){if(!(b[lb].x==a[i].x&&b[lb].y==a[i].y)){b[lb++] = a[i];}}int cnt = 0;for(int i = 0;i<lb;i++){for(int j = 0;j<lb;j++){if(a[i].x<a[j].x&&a[i].y<a[j].y){if(find(a[i].x,a[j].y)==true&&find(a[j].x,a[i].y)==true){cnt++;}}}}cout<<cnt;return 0;
}
bool cmp(point a,point b)
{if(a.x==b.x) return a.y<b.y;else return a.x<b.x;
}
bool find(int x,int y)
{for(int i = 0;i<lb;i++){if(b[i].x==x&&b[i].y==y){return true;}}return false;
}

 

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com