9.1 NOIP普及组试题精解(3)
9-6 seat.c
#include <stdio.h>
#define MAXN 1001
void swap(int *a, int *b) //交换数据
{
int t;
t = *a;
*a = *b;
*b = t;
}
int main()
{
FILE *fp1, *fp2;
int row[MAXN], col[MAXN], temp[MAXN];
int m, n, k, l, d; //m行n列,k条横向通道,l条纵向通道,d对同学上课说话
int x1, y1, x2, y2; //两个相互说话同学的位置
int i, j;
if ((fp1 = fopen("seat.in", "r")) == NULL)
{
printf("不能打开文件!\n");
exit();
}
fscanf(fp1, "%d%d%d%d%d\n", &m, &n, &k, &l, &d);
; i <= m; i++) //设置不插入横向通道
row[i] = ;
; i <= n; i++) //设置不插入纵向通道
col[i] = ;
; i < d; i++) //读入文件中每行的数据,统计在每行、每列添加通道可以分割的学生数
{
fscanf(fp1, "%d%d%d%d", &y1, &x1, &y2, &x2); //读入要说话的两个坐标位置
if (x1 == x2) //若在同一列
{
if (y1 > y2)
swap(&y1, &y2); //交换列号,使低列号排在前面
row[y1]++; //在y1位置增加一条横向通道分隔同一列的同学
} else if (y1 == y2) //在同一行
{
if (x1 > x2)
swap(&x1, &x2); //交换行号,使低行号排在前面
col[x1]++; //在x1位置增加一条纵向通道分隔同一行的同学
}
}
fclose(fp1); //关闭文件
; i <= m; i++) //temp中保存行号,准备排序
temp[i] = i;
; i < m; i++) //对横向通道分隔说话学生对数进行排序
; j <= m; j++)
if (row[i] < row[j]) //第i行设通道分隔说话学生少于第j行
{
swap(&row[i], &row[j]); //交换通道位置
swap(&temp[i], &temp[j]); //交换行号
}
; i < k; i++) //对前k条横向通道进行排序
; j <= k; j++)
if (temp[i] > temp[j]) //使低行号排在前面
swap(&temp[i], &temp[j]);
if ((fp2 = fopen("seat.out", "w")) == NULL)
{
printf("不能打开文件!\n");
exit();
}
; i <= k; i++) //输出横向通道位置
{
printf(" %d", temp[i]);
fprintf(fp2, " %d", temp[i]);
}
printf("\n");
fprintf(fp2, "\n");
; i <= n; i++) //将列号保存到temp数组中,准备排序
temp[i] = i;
; i < n; i++) //对纵向通道分隔说话学生对数进行排序
; j <= n; j++)
if (col[i] < col[j])
{
swap(&col[i], &col[j]); //交换通道位置
swap(&temp[i], &temp[j]); //交换列号
}
; i < l; i++) //对前L条纵向通道进行排序
; j <= l; j++)
if (temp[i] > temp[j]) //使低列号排在前面
swap(&temp[i], &temp[j]);
; i <= l; i++) //输出纵向通道
{
printf(" %d", temp[i]);
fprintf(fp2, " %d", temp[i]);
}
fprintf(fp2, "\n");
fclose(fp2);
getch();
;
}
9.1 NOIP普及组试题精解(3)的更多相关文章
- 9.1 NOIP普及组试题精解(2)
9-4 soldier.c #include <stdio.h> #define MAXN 21 }; int n, m, x, y; //n,m为B点的行列坐标位置,x,y为马的坐标位置 ...
- 9.1 NOIP普及组试题精解(1)
9-1 series1.c #include <stdio.h> int main() { float s=0.0,k; int n; printf("输入数字k(1~15):& ...
- 9.2 NOIP提高组试题精解(2)
9-18 fruit.c #include <stdio.h> #define MAXN 10000 int Queue1[MAXN], Queue2[MAXN]; void Insert ...
- 9.2 NOIP提高组试题精解(1)
9-16 poise.c #include <stdio.h> #define MAXN 1001 int main() { ], flag[MAXN] = { }; //保存6种砝码的数 ...
- 2016.10.6初中部上午NOIP普及组比赛总结
2016.10.6初中部上午NOIP普及组比赛总结 中了病毒--病毒--病毒-- 进度: 比赛:AC+0+0+20=120 改题:AC+0+AC+20=220 Stairs 好--简--单!递推就过了 ...
- 2016.8.15上午纪中初中部NOIP普及组比赛
2016.8.15上午纪中初中部NOIP普及组比赛 链接:https://jzoj.net/junior/#contest/home/1333 这次比赛不怎么好,因为这套题目我并不是很擅长. 可同学们 ...
- 2016.9.15初中部上午NOIP普及组比赛总结
2016.9.15初中部上午NOIP普及组比赛总结 2016.09.15[初中部 NOIP普及组 ]模拟赛 又翻车了!表示时超和空超很可恨! 进度 比赛:AC+0+0+20=120 改题:AC+80+ ...
- 2016.9.10初中部上午NOIP普及组比赛总结
2016.9.10初中部上午NOIP普及组比赛总结 链接:https://jzoj.net/junior/#contest/home/1340 好不爽!翻车了!不过排名差不多在中间偏上一点, 还好不是 ...
- 2016.9.3初中部上午NOIP普及组比赛总结
2016.9.3初中部上午NOIP普及组比赛总结 链接:https://jzoj.net/junior/#contest/home/1339 这次真爽,拿了个第四!(我还被班主任叫过去1小时呢!) 进 ...
随机推荐
- 2017.2.7 开涛shiro教程-第六章-Realm及相关对象(一)
原博客地址:http://jinnianshilongnian.iteye.com/blog/2018398 根据下载的pdf学习. 第六章 Realm及相关对象 1.用户.角色.权限的关系 用户和角 ...
- maven仓库中有jar包pom还报错
maven仓库中有jar包pom还报错 就报错,咋啦? 这个包来源不明,自己拷贝进来的吧?你当我mvn是傻子?我要去网上验证一下: 我自己有个_remote.respositories文件,如果自己用 ...
- 多媒体层预览(Media Layer OverView)
音频模块位于多媒体层里.多媒体层包含了图形.音频.视频三种技术.这三种技术会给你带来声觉.视觉上的良好体验. 来看看ios的结构体系以及媒体层上的内容: ...
- linux 内核(系统)、函数的理解、宏的程序调试
1.操作系统 1.1.Linux 内核(系统)的组成的部分: 内核主要有:进程调度.内存管理.虚拟文件系统.网络接口和进程通信五个部分组成. (1)进程调度 进程调度是CPU对多个进程对CPU访问的调 ...
- H5和CSS3新增内容总结
CSS3选择器有哪些?答:属性选择器.伪类选择器.伪元素选择器.CSS3新特性有哪些?答:1.颜色:新增RGBA,HSLA模式 文字阴影(text-shadow.) 边框: 圆角(border-rad ...
- 设计模式之单利模式(C#语言描述,附视频下载地址)
今天来介绍所有设计模式中结构最简单的设计模式单例模式,它的核心结构中只包含一个被称为单例类的特殊类. 要想完成单例类的设计,我们要遵循一下原则即可: 1.一个类只能有一个实例 2.确保该实例对外有一个 ...
- jQuery--基础(实例)
jQuery的操作方法并不需要都记下来,但是使用什么功能需要什么样的方法,我们是一定会知道的.所以写实例来进行对功能方法的练习和熟练,是最快能够掌握jQuery的方法. <!DOCTYPE ht ...
- Failed to fetch URL https://dl-ssl.google.com/android/repository/addons_list-2.xml, reason: Connect
Failed to fetch URL https://dl-ssl.google.com/android/repository/addons_list-2.xml, reason: Connect ...
- js将字符串转变成数字
方法主要有三种 转换函数.强制类型转换.利用js变量弱类型转换. 1. 转换函数: js提供了parseInt()和parseFloat()两个转换函数.前者把值转换成整数,后者把值转换成浮点数.只有 ...
- centos安装python3.7.0过程记录
参考自这里,整理出以下步骤. 一.下载python3.7.0包地址:https://www.python.org/ftp/python/3.7.0/Python-3.7.0.tgz 二.安装 登陆Li ...