2019年全国高校计算机能力挑战赛 C语言程序设计决赛

毕竟这个比赛是第一次举办,能理解。。

希望未来再举办时,能够再完善一下题面表述、数据范围。

话说区域赛获奖名额有点少吧。舍友花60块想混个创新创业分也太难。。

水进了决赛圈,一共6题。

前4题,大概C语言课后习题的难度?

第5题,贪心排个序就好了吧

第6题,图论,拓扑排序,但我用暴力的,因为不知道范围呀,希望能骗点分。

第1题

#include<stdio.h>

const int maxn = 10050;
char s[maxn];
int cnt[5]; int main(){
char c;
int pos = 0;
while((c = getchar()) != EOF){
s[pos++] = c;
}
for(int i=0;i<pos;i++){
if(s[i] == '+') cnt[1]++;
else if(s[i] == '-') cnt[2]++;
else if(s[i] == '*') cnt[3]++;
else if(s[i] == '/') cnt[4]++;
}
printf("+ %d\n",cnt[1]);
printf("- %d\n",cnt[2]);
printf("* %d\n",cnt[3]);
printf("/ %d\n",cnt[4]);
return 0;
}

第2题

#include<stdio.h>

const int maxn = 450;
int n;
int a[maxn][maxn]; int main(){
scanf("%d",&n);
for(int i=1;i<=n;i++){
for(int j=1;j<=n;j++){
scanf("%d",&a[i][j]);
}
}
int cnt = 0;
for(int i=1;i<=n;i++){
if(a[i][i] > 0)
cnt++;
}
for(int i=1;i<=n;i++){
int pos = n-i+1;
if(pos == i) continue;
else{
if(a[i][pos] > 0)
cnt++;
}
}
printf("%d",cnt);
return 0;
}
/*
4
1 2 3 4
5 6 7 8
9 0 0 12
1 0 0 -16
*/

第3题

#include<stdio.h>

typedef long long ll;
const int maxn = 1010;
int n;
ll a[maxn];
ll b[maxn]; int main(){
scanf("%d",&n);
bool flag = true;
for(int i=1;i<=n;i++){
scanf("%ld",&a[i]);
int temp = a[i];
int min_x = 9;
while(temp){
if(temp%10 < min_x) min_x = temp%10;
temp /= 10;
}
ll new_num;
if(a[i] == 0){
new_num = a[i];
b[i] = new_num;
flag = false;
}else{
ll new_num = (a[i]/100*10+min_x)*10+min_x;
b[i] = new_num;
if(b[i] == a[i]) flag = false;
}
}
if(flag == true){
printf("Done");
for(int i=1;i<=n;i++) printf(" %ld",b[i]);
}else{
printf("Error");
for(int i=1;i<=n;i++) {
if(b[i] == a[i]) printf(" %ld",b[i]);
}
}
return 0;
} /*
4
321 96 5 232
3
0 9 322
*/

第4题

#include<stdio.h>

const int maxn = 10010;
char s[maxn];
char ans[maxn];
int pos = 0; void solve(int start,int ends){
for(int i=start;i<ends;i++){
for(int j=start+1;j<ends;j++){
if((s[i] >= 'A' && s[i] <= 'Z') || (s[i] >= 'a' && s[i] <= 'z')){
if((s[j] >= 'A' && s[j] <= 'Z') || (s[j] >= 'a' && s[j] <= 'z')){
if(s[i] == (s[j] + 1) || s[i] == (s[j] - 1)){
ans[pos++] = ' ';
for(int j=start;j<ends;j++){
ans[pos++] = s[j];
}
return;
}
}
}
}
}
} int main(){
// freopen("out.txt","w",stdout);
char c;
int start = 0;
int ends = 0;
while((c = getchar()) != EOF){
s[ends++] = c;
if(c == '.'){ //处理最后一个
solve(start,ends-1);
break;
}
if(c == ' '){
solve(start,ends-1);
start = ends;
}
}
if(pos == 0) printf("Accept!");
else{
for(int i=1;i<pos;i++) printf("%c",ans[i]);
}
return 0;
} /*
There is nothing can stop us from hard working.
nothing stop working
hi st There is a cat in the box. */

第5题

#include<stdio.h>

const int maxn = 10010;
int n;
int a[maxn];
int b[maxn]; int qusort(int s[],int start,int end)
{
int i,j;
i=start;
j = end;
s[0]=s[start];
while(i<j)
{
while(i<j&&s[0]<s[j])
j--;
if(i<j)
{
s[i]=s[j];
i++;
}
while(i<j&&s[i]<=s[0])
i++;
if(i<j)
{
s[j]=s[i];
j--;
}
}
s[i]=s[0];
if (start<i)
qusort(s,start,j-1);
if (i<end)
qusort(s,j+1,end);
return 0;
} int main(){
scanf("%d",&n);
for(int i=1;i<=n;i++){
scanf("%d",&a[i]);
}
for(int j=1;j<=n;j++){
scanf("%d",&b[j]);
}
qusort(a,1,n);
qusort(b,1,n);
int pos = 1;
int cnt = 0;
for(int i=1;i<=n;i++){
if(a[i] > b[pos]){
cnt++;
pos++;
}
}
printf("%d",cnt);
return 0;
}
/*
6
2 13 26 33 45 9
3 8 30 15 18 40
*/

第6题

dfs暴力找最长的拓扑路径

#include<stdio.h>

const int maxn = 400;
int g[maxn][maxn];
int n;
int a[maxn];
int ans = 0;
int in[maxn];
int out[maxn];
int c; void dfs(int x,int cur){
if(x == c){
if((cur-a[c]) > ans) ans = cur-a[c];
return;
}
for(int i=1;i<=n;i++){
if(i == x) continue;
if(i!=c && out[i] == 0) continue;
if(g[x][i] == 1){
dfs(i,cur+a[i]);
}
}
} int main(){
scanf("%d",&n);
for(int i=1;i<=n;i++){
scanf("%d",&a[i]);
}
int u,v;
while(scanf("%d%d",&u,&v) && u!=-1 && v!=-1){
if(g[u][v] == 0){
g[u][v] = 1;
in[v]++;
out[u]++;
}
}
scanf("%d",&c);
if(in[c] == 0) printf("0");
else{
for(int i=1;i<=n;i++){
if(i == c) continue;
if(out[i] == 0) continue;
dfs(i,a[i]);
}
printf("%d",ans);
}
return 0;
} /*
4
8 12 16 10
1 2
2 3
4 2
1 3
-1 -1
3 3
8 12 16
1 2
1 3
-1 -1
3
*/

队友用拓扑排序做的

#include<iostream>
#include<stack>
#include<vector>
#include<algorithm>
#include<cmath>
#include<queue>
#include<cstring>
using namespace std;
typedef long long ll;
struct node{
vector<int> zi;
int day;
int ind;
int maxT;
vector<int> last;
int cost;
}sub[500];
vector<int> ans;
int n,c;
void toposort() {
queue<int> q;
for (int i = 1; i <=n; i++)
if (sub[i].ind == 0) q.push(i);
while (!q.empty()) {
int u = q.front();
q.pop();
ans.push_back(u);
for(int i = 0;i<sub[u].last.size ();i++ ){
int cur = sub[u].last[i];
sub[u].maxT = max(sub[cur].cost,sub[u].maxT );
}
sub[u].cost = sub[u].day + sub[u].maxT ;
sub[u].maxT = sub[u].cost ;
for(int i = 0;i<sub[u].zi.size() ;i++ ){
int cur = sub[u].zi[i];
if(--sub[cur].ind == 0 ){
q.push(cur);
}
}
}
return ;
}
int main(){
cin>>n;
for(int i = 1;i<=n;i++){
int t;
cin>>t;
sub[i].day = t;
sub[i].ind = 0;
sub[i].maxT = 0;
sub[i].cost = 0;
}
while(1){
int a,b;cin>>a>>b;
if(a == -1 && b == -1){
break;
}
sub[a].zi.push_back(b);
sub[b].last.push_back(a);
sub[b].ind ++;
}
cin>>c;
toposort();
cout<<sub[c].cost - sub[c].day ;
return 0;
}

2019年全国高校计算机能力挑战赛 C语言程序设计决赛的更多相关文章

  1. 2019年全国高校计算机能力挑战赛初赛C语言解答

    http://www.ncccu.org.cn 2019年全国高校计算机能力挑战赛分设大数据算法赛,人工智能算法赛,Office高级应用赛,程序设计赛4大赛项 C语言初赛解答 1:编程1 16.现有一 ...

  2. 2019年全国高校计算机能力挑战赛初赛java语言解答

    1:题目1 16.某星球存在两种生物,A种生物有1个头6条腿,B种生物有3个头4条腿.来自地球的太空船刚刚在该星球降落,突然发现一大群这两种生物组成的队伍,由于时间紧,只数了头的数量和腿的数量,请帮助 ...

  3. 2019年全国高校计算机能力挑战赛初赛C++语言解答

    1; 题目一 16.电商促销某种商品时,希望通过打折鼓励消费者组团消费.已知,团队消费金额=该团的人数和*商品单价.打折规则如下:当组团消费者数量不满50人时,商品消费金额没有折扣:消费者数量大于等于 ...

  4. 2019年全国高校sql数据库

    2019年全国高校名单sql数据库信息: 根据教育部发布的文件整理形成可用.sql文件,导入数据库即可使用. 包括全国高等学校共计2956所,其中:普通高等学校2688所(含独立学院257所),成人高 ...

  5. 全国计算机等级考试二级Python语言程序设计考试大纲

    全国计算机等级考试二级Python语言程序设计考试大纲(2018年版) 基本要求 掌握Python语言的基本语法规则. 掌握不少于2个基本的Python标准库. 掌握不少于2个Python第三方库,掌 ...

  6. Python3——2019年全国大学生计算二级考试

    Python语言程序设计二级重点(2019年版) 第一章 程序设计基本方法 IPO程序编写方法 :输入(input),输出(output),处理(process): Python程序的特点: (1)语 ...

  7. 2019年湖南省大学生计算机程序设计竞赛 (HNCPC2019) 简要题解

    2019年湖南省大学生计算机程序设计竞赛 (HNCPC2019) 简要题解 update10.01 突然发现叉姐把这场的题传到牛客上了,现在大家可以有地方提交了呢. 不知道该干什么所以就来水一篇题解 ...

  8. 2019年春季学期《C语言程序设计II》课程总结

    2019年春季学期<C语言程序设计II>课程总结 1.课程情况 教学内容 课堂小结 作业安排 优秀作业 备注 1.开学谈心 2.测验数据类型.运算符与表达式的自学情况,并讲解测验题目3.第 ...

  9. 2019年春季学期《C语言程序设计II》助教注意事项

    本学期<C语言程序设计II>课程安排 理论课时24(1-12周),实验课时8(13周),课程设计课时16(14-15周) 理论课教学内容 附:教学进度表 本学期实验课和课程设计参考教材 & ...

随机推荐

  1. docker-网络模式

    Docker自身的4种网络工作方式,和一些自定义网络模式 安装Docker时,它会自动创建三个网络,bridge(创建容器默认连接到此网络). none .host host:容器将不会虚拟出自己的网 ...

  2. 【Java SE】使用Javacv截取视频图片

    [Java Web开发学习]使用Javacv截取视频图片 转载:https://www.cnblogs.com/yangchongxing/p/9482935.html github地址:https: ...

  3. 70道阿里百度高频Java面试题(框架+JVM+多线程+算法+数据库)

    基础与框架 1.String类能被继承吗,为什么 2.String,Stringbuffer,StringBuilder的区别? 3.ArrayList和LinkedList有什么区别 4.类的实例化 ...

  4. Java并发编程系列-(6) Java线程池

    6. 线程池 6.1 基本概念 在web开发中,服务器需要接受并处理请求,所以会为一个请求来分配一个线程来进行处理.如果每次请求都新创建一个线程的话实现起来非常简便,但是存在一个问题:如果并发的请求数 ...

  5. ASP.NET Core开发者指南()

    你可以在下面找到一张图,该图展示了你可以选取的路径及你想学习的库,从而成为一名 ASP.NET Core 开发者.“作为 ASP.NET Core 开发者,我接下来应该学习什么?”,我把这张图作为建议 ...

  6. 五分钟学会conda常用命令

    文章目录 conda常用命令 1. 获取版本号 2. 获取帮助 3. 环境管理 4. 分享环境 5. 包管理 conda常用命令 1. 获取版本号 conda --version 或 conda -V ...

  7. 如何下载Vimeo视频

    MediaHuman YouTube Downloader是应用在Mac上的一款非常优秀的YouTube视频下载工具,YouTube Downloader破解版将帮助你快速完成视频下载,而不会挂断.您 ...

  8. Linux命令-grep,sed,awk

    grep (global search regular expression[RE] and print out the line) 正则表达式全局搜索并将行打印出来 在文件中查找包含字符串" ...

  9. glusterFS空间不够了怎么办

    查看glusterFS情况 oc project infra-storage oc get all #找到其中一个pod,前缀为 po/glusterfs-registry-xxxx oc exec ...

  10. Docker异常:/lib/x86_64-linux-gnu/libnss_files.so.2: symbol __libc_readline_unlocked, version GLIBC_PRIVATE not defined in file libc.so.6 with link time reference

    当使用docker cp 将容器内数据拷贝至主机时,或是使用docker export 命令归档容器文件时,出现下述异常: Error response from daemon: error proc ...