B - Yet Another Crosses Problem

题意:找如果使图中某一行某一列全部变成黑色,至少需要把多少个白方格变成黑方格

思路:直接找就可以,注意存储的时候要记得进行分开存储,存储每一行多少个白方格用一个数组,存储每一列多少个白方格用一个数组,最后再进行判断最少的是多少

代码:

 1 #include<iostream>
2 #include<algorithm>
3 #include<cmath>
4 #include<cstring>
5 #include<cstdio>
6 using namespace std;
7 const int maxx=50010;
8
9
10 int main(){
11 int t;
12 scanf("%d",&t);
13 while(t--){
14 int n,m;
15 scanf("%d %d",&n,&m);
16 int a[n][m];
17 int b[n+11]={0};
18 int c[m+11]={0};
19 char s;
20 for(int i=0;i<n;i++){
21 getchar();
22 for(int j=0;j<m;j++){
23 scanf("%c",&s);
24 if(s=='*'){
25 a[i][j]=0;
26
27 }else{
28 a[i][j]=1;
29 b[i]++;
30 c[j]++;
31 }
32
33 }
34
35 }
36 int minn=9e6;
37 for(int i=0;i<n;i++){
38 for(int j=0;j<m;j++){
39 int s=b[i]+c[j]-a[i][j];
40 minn=min(minn,s);
41 }
42
43 }
44 printf("%d\n",minn);
45
46
47 }
48 }

7-9 排座位

题意:布置宴席最微妙的事情,就是给前来参宴的各位宾客安排座位。无论如何,总不能把两个死对头排到同一张宴会桌旁!这个艰巨任务现在就交给你,对任何一对客人,请编写程序告诉主人他们是否能被安排同席。

思路:输入的i号宾客和j号宾客对应某种关系,就用一个数组的第i行第j列存入其对应关系,第j行第i列存入其对应关系,当查找其关系时进行数组遍历寻找,找其所在行所在列是否存在1或者-1,进行查找其关系,一定主意判断条件应该是相乘为1,并不是两个都为1,

代码:

 1 #include<iostream>
2 #include<algorithm>
3 #include<cstring>
4 #include<cmath>
5 #include<cstdio>
6 using namespace std;
7 int main(){
8 int n,m,k;
9 scanf("%d %d %d",&n,&m,&k);
10 int a[n+2][n+2]={0};
11 for(int i=0;i<m;i++){
12 int h,l,num;
13 scanf("%d %d %d",&h,&l,&num);
14 a[h][l]=num;
15 a[l][h]=num;
16 }
17 while(k--){
18 int num1,num2;
19 scanf("%d %d",&num1,&num2);
20 if(a[num1][num2]==1){
21 printf("No problem\n");
22 }else if(a[num1][num2]==0){
23 printf("OK\n");
24 }else{
25 int flag=0;
26 for(int i=0;i<n;i++){
27 if(a[num1][i]*a[num2][i]==1){//一定注意
28 flag=1;
29 }
30 }
31 if(a[num1][num2]==0&&flag==1){
32 printf("No problem\n");
33 }else if(a[num1][num2]==0&&flag==0){
34 printf("OK\n");
35 }else if(a[num1][num2]==-1&&flag==1){
36 printf("OK but...\n");
37 }else{
38 printf("No way\n");
39 }
40 }
41 }
42 }

7-11 重排链表

题意:给定一个单链表 L​1​​→L​2​​→⋯→L​n−1​​→L​n​​,请编写程序将链表重新排列为 L​n​​→L​1​​→L​n−1​​→L​2​​→⋯。例如:给定L为1→2→3→4→5→6,则输出应该为6→1→5→2→4→3。

思路:需要开设两个结构体,一个讲address作为存储的下标,然后通过这样存储以后,再进行开设第二个同类型的结构体,进行存入,主要是从第一个结构体的顺序上添加了他们的相对位置序号,输出的时候也要进行分开输出,不要两个两个的输出,就直接一个一个输出分开奇偶位置的数就好,不然还要分奇偶进行输出,就很麻烦

注意:1.存储的时候,看着样例以为data位置上就是他们的相对位置,直接进行这样输出了,结果就是错的,数据没有特殊性;2.数据输出的时候不要固化直接两个两个输出,一个一个分开奇偶位进行输出也好;3.用一个新的n更新结构体中链表的长度,因为会存在多余结点,导致出现很多的-1等等问题

代码:

 1 #include<iostream>
2 #include<algorithm>
3 #include<cstdio>
4 #include<cmath>
5 #include<cstring>
6 using namespace std;
7 const int maxx=1e5+2;
8 struct num{
9 int address,data,next,numm;
10 }point[maxx],ss[maxx];
11 bool cmp(num& a,num& b){
12 return a.numm<b.numm;
13 }
14 int main(){
15 int start,n;
16 scanf("%d %d",&start,&n);
17 int p;
18 for(int i=0;i<n;i++){
19 scanf("%d",&p);
20 scanf("%d %d",&point[p].data,&point[p].next);
21 }
22 p=start;
23 int i=1;
24 int sum=0;
25 while(p!=-1){
26 ss[i].address=p;
27 ss[i].data=point[p].data;
28 ss[i].next=point[p].next;
29 i++;
30 p=point[p].next;
31 sum++;
32 }
33
34 int j=0;
35 int left=1,right=sum;
36 while(sum--){
37 j++;
38 if(j%2==1){
39 if(sum!=0){
40 printf("%05d %d %05d\n",ss[right].address,ss[right].data,ss[left].address);
41 right--;
42 }else{
43 printf("%05d %d -1\n",ss[right].address,ss[right].data);
44
45 }
46
47 }else{
48 if(sum!=0){
49 printf("%05d %d %05d\n",ss[left].address,ss[left].data,ss[right].address);
50 left++;
51 }else{
52 printf("%05d %d -1\n",ss[left].address,ss[left].data);
53 }
54
55 }
56 }
57 }

7-12 分而治之

题意:分而治之,各个击破是兵家常用的策略之一。在战争中,我们希望首先攻下敌方的部分城市,使其剩余的城市变成孤立无援,然后再分头各个击破。为此参谋部提供了若干打击方案。本题就请你编写程序,判断每个方案的可行性。(其实就是找所给点是否可以遍历完所有的马路)

思路:进行结构体存储输入的一条路对应的两个城市,用数组中0.1去重的相似方法进行查找,所给攻破城市存入一个新的数组中,然后用结构体中的两个城市比较看是否两个城市都为初始值0

注意:1.一开始的时候用二维数组进行存储路线,后来因为循环太多出现了段错误;2.此题应该用已知去比较,而不是用所给攻破城市和已知去比较,因为此时的攻破城市已经在同一层面上,也就是都存入了一个一维数组中,不用逐个去比较

 1 #include<iostream>
2 #include<algorithm>
3 #include<cstdio>
4 #include<cmath>
5 #include<cstring>
6 using namespace std;
7 const int maxx=1e4+6;
8 struct point{
9 int a,b;
10 }p[maxx];
11 int main(){
12 int n,m;
13 scanf("%d %d",&n,&m);
14 for(int i=0;i<m;i++){
15 scanf("%d %d",&p[i].a,&p[i].b);
16 }
17 int np;
18 scanf("%d",&np);
19 while(np--){
20 int k;
21 int c[maxx]={0};
22 scanf("%d",&k);
23 int v;
24 for(int i=0;i<k;i++){
25 scanf("%d",&v);
26 c[v]=1;
27 }
28 int flag=0;
29 for(int i=0;i<m;i++){
30 if(c[p[i].a]==0&&c[p[i].b]==0){
31 flag=1;
32 }
33 }
34 if(flag==1){
35 printf("NO\n");
36 }else{
37 printf("YES\n");
38 }
39 }
40 }

QFNU 10-02 19 training的更多相关文章

  1. 2016年10月19日 星期三 --出埃及记 Exodus 19:3

    2016年10月19日 星期三 --出埃及记 Exodus 19:3 Then Moses went up to God, and the LORD called to him from the mo ...

  2. phpStudy + JspStudy 2014.10.02 下载

    phpStudy + JspStudy 2014.10.02 下载 目标:让天下没有难配的php环境. phpStudy Linux版&Win版同步上线 支持Apache/Nginx/Teng ...

  3. Nanjing GDG Meetup 10月19日线下活动

     Nanjing GDG 10 月份的线下活动将在本周六 (10/19) 举办,这次会请到对所有开发者都有重要帮助的神器 GoAgent 的作者 Phus Lu 来给我们做一场分享,热烈欢迎大家报名参 ...

  4. 北京Uber优步司机奖励政策(10月19日~10月25日)

    用户组:优步北京人民优步A组(适用于10月19日-10月25日) 滴快车单单2.5倍,注册地址:http://www.udache.com/ 如何注册Uber司机(全国版最新最详细注册流程)/月入2万 ...

  5. 欢迎来怼-Alpha周(2017年10月19)贡献分配规则和分配结果

    .从alpha周(2017年10月19日开始的2周)开始,提高贡献分比重. 贡献分 : 团队分 = 1 : 5 教师会在核算每位同学总分时按比例乘以系数. 每位同学带入团队贡献分10分,如果团队一共7 ...

  6. delphi 颜色 引用http://www.cnblogs.com/del/archive/2008/02/19/1073568.html

    颜色名称   颜色效果   Hex HTML clBlack   $000000 #000000 clMaroon   $000080 #800000 clGreen   $008000 #00800 ...

  7. 07/29/2013 02:10:02 AM - CMDPHP: Poller[0] Host[6] DS[10] WARNING: Result from SNMP not valid. Partial Result: U

    snmpwalk -c public -v2c  客户端ip地址  自定义的oid  能取到数据,但是服务器端就是图片一片空白 rrdtool fetch 文件名.rrd 查看到的全都是nan cac ...

  8. fastjson转换包含date类型属性的对象时报错com.alibaba.fastjson.JSONException: For input string: "13:02:19"

    问题:time类型数据插入不进mysql数据库:调试的时候报如下错误: Caused by: java.lang.NumberFormatException: For input string: &q ...

  9. 腾讯云 CIF 工程效能峰会,10 月 19 - 20 日震撼来袭!

    近年来,依托于云计算的飞速发展,腾讯云云产品更新迅猛,云原生生态构建初具规模,越来越多的企业也开始寻求与深入数字化转型之路.但在摸索与实践中,企业往往会进入"伪上云"的误区.除了单 ...

随机推荐

  1. 多种细分方式浏览销售数据,IAP助您有效洞察市场收益效果

    华为应用内支付服务是直接在应用程序内提供购买商品或订阅等功能,为了能够让开发者更好的了解应用内的销售额及商品购买.订阅的市场收益效果,华为应用内支付服务提供的消费数据统计和数据报表,支持多种细分方式浏 ...

  2. ASP.Net Core中处理异常的几种方法

    本文将介绍在ASP.Net Core中处理异常的几种方法 1使用开发人员异常页面(The developer exception page) 2配置HTTP错误代码页 Configuring stat ...

  3. Github Actions 还能做这些事

    前言 最近公司内部项目的发布流程接入了 GitHub Actions,整个体验过程还是比较美好的:本文主要目的是对于没有还接触过 GitHub Actions的新手,能够利用它快速构建自动测试及打包推 ...

  4. java例题_47 读取 7 个数(1—50)的整数值,每读取一个值,程序打印出该值个数的*

    1 /*47 [程序 47 打印星号] 2 题目:读取 7 个数(1-50)的整数值,每读取一个值,程序打印出该值个数的*. 3 */ 4 5 /*分析 6 * 1.多次读取---for循环 7 * ...

  5. 第11 章 : 可观测性:你的应用健康吗?(liveness和readiness)

    课时 11:可观测性:你的应用健康吗?(莫源) 本次课程的分享主要围绕以下五个部分: 介绍一些整体需求的来源: 介绍在 K8s 中 Liveness 和 Readiness 的使用方式: 介绍在 K8 ...

  6. 【JVM进阶之路】十:JVM调优总结

    1.调优原则 JVM调优听起来很高大上,但是要认识到,JVM调优应该是Java性能优化的最后一颗子弹. 比较认可廖雪峰老师的观点,要认识到JVM调优不是常规手段,性能问题一般第一选择是优化程序,最后的 ...

  7. Linux(六):系统运维常用命令

    实际的生产环境下,不论是研发还是运维,或多或少的得面对在linux上定位问题这个关卡,这里介绍一下linux环境下一些状态查看常用的命令. 系统资源监控 总体资源占用情况查看 命令:top 像wind ...

  8. Spring Boot 轻量替代框架 Solon 1.3.20 发布

    Solon 是一个微型的Java开发框架.项目2018年启动,参考过大量前人作品:内核0.1m的身材,超高的跑分,以及良好的使用体验.支持:RPC.REST API.MVC.WebSocket.Soc ...

  9. SpringBoot+Gradle构建多模块项目

    1 概述 Gradle由于构建速度比Maven快,且比Maven灵活,因此很多后端的应用都使用了Gradle进行构建,但一个问题是,Gradle的多模块项目比较难构建,再加上Gradle的更新非常快, ...

  10. NumPy之:标量scalars

    目录 简介 scalar类型的层次结构 内置Scalar类型 boolean Integers Unsigned integers Floating-point numbers Complex flo ...