9509 开灯

9509 开灯

时间限制:1000MS  内存限制:65535K
提交次数:0 通过次数:0

题型: 编程题   语言: G++;GCC

Description

有16的开关分别控制16盏灯,开关排列成4*4的矩形,这些开关有这样的关系:
你改变其中一个开关的状态,与其同行和同列的开关的状态也跟着改变。先给出一个这些开关的初始状态,要求将所有的开关都打开,让所有的灯都亮起来,要求按下开关的次数最少。

输入格式

第一行输入一个整数t,表示有多少个case,每个case之间有一空行,每个case输入一个0、1组成的4*4的矩阵,0表示开关状态为关,1表示开关状态为开。

输出格式

每个case输出一行,让所有灯都亮的最少按开关数。

输入样例

1
1011
1111
1111
1011

输出样例

6

提示

分别按下(1,1),(1,3),(1,4),(4,1),(4,3),(4,4)6个开关就行了
对于
1111
1011
1111
1111
要把第二行和第二列的灯各按一次。

来源

Zyq

作者

a470086609

如果只是为了ac掉这道题目的话可以不用任何算法,只要按它最后给的提示找规律就可以了。至于怎么找出来的,自己去想(其实我不知道怎么解释=.=)... 大致如下:在一个4*4的表中输入完数据后,从头到尾扫一遍,如果遇到‘0‘的话就把它同行和同列的灯都按一次;如果有哪些灯被按了2n(n为整数)次的话,其被按的次数就会被抵消掉(即被按了0次),但如果是2n+1(n为整数)次的话,就算是被按了一次。另外,需要将被按过的灯存放在另一个表里面好在最后统计总共的按灯次数。

XJB扯了一通...感觉表达的并不清楚...可能不一定看的懂...那就索性别看解释直接看代码然后自己在纸上模拟一遍吧。。。

(这道题是可以用dfs过的。。。稍后更新。。。)

 1 #include <stdio.h>
 2
 3 int main()
 4 {
 5     int T,i,j,t_i,t_j;
 6     scanf("%d",&T);
 7     getchar();
 8     while(T--)
 9     {
10
11         int book[10][10];int cnt=0;
12         char a[10][10];
13         //初始化标记数组
14         for(i=0;i<4;i++)
15             for(j=0;j<4;j++)
16                 book[i][j]=0;
17         //
18         for(i=0;i<4;i++)
19         {
20             for(j=0;j<4;j++)
21                 scanf("%c",&a[i][j]);
22             getchar();
23         }
24         //
25         for(i=0;i<4;i++)
26             for(j=0;j<4;j++)
27                 if(a[i][j]==‘0‘)
28                 {
29                     for(t_j=0;t_j<4;t_j++)
30                     {
31                         if(book[i][t_j]==0)
32                             book[i][t_j]=1;
33                         else book[i][t_j]=0;
34                     }
35                     for(t_i=0;t_i<4;t_i++)
36                     {
37                         if(t_i==i) continue;
38                         if(book[t_i][j]==0)
39                             book[t_i][j]=1;
40                         else book[t_i][j]=0;
41                     }
42                 }
43         //
44         for(i=0;i<4;i++)
45             for(j=0;j<4;j++)
46                 if(book[i][j]==1)
47                     cnt++;
48         printf("%d\n",cnt);
49         if(T != 0) getchar();
50         }
51     return 0;
52 }
时间: 2024-10-11 05:43:21

9509 开灯的相关文章

9509 开灯(dfs)

9509 开灯 时间限制:1000MS  内存限制:65535K提交次数:0 通过次数:0 题型: 编程题   语言: G++;GCC Description 有16的开关分别控制16盏灯,开关排列成4*4的矩形,这些开关有这样的关系: 你改变其中一个开关的状态,与其同行和同列的开关的状态也跟着改变.先给出一个这些开关的初始状态,要求将所有的开关都打开,让所有的灯都亮起来,要求按下开关的次数最少. 输入格式 第一行输入一个整数t,表示有多少个case,每个case之间有一空行,每个case输入一

开灯问题

有n盏灯,编号1-n.第1个人把所有灯打开,第2个人按下所有编号为2的倍数的开关(这些灯将被关掉),第3个人按下所有编号为3的倍数的开关(其中关掉的灯将被打开,开着的灯将被关闭),依次类推.一共有k个人,问最后由哪些灯开着? 输入n和k,1≤k≤n≤1000.输出开着的灯编号. 样例输入: 7 3 样例输出: 1 5 6 7 分析: 使用memset函数,将数组中一定长度中的内容替换成指定字符.其中有三个参数,第一个是需要替换的数组,第二个是替换的值,第三个是长度值,一般使用sizeof函数.

开灯问题(南阳oj77)

开灯问题 时间限制:3000 ms  |  内存限制:65535 KB 难度:1 描述 有n盏灯,编号为1~n,第1个人把所有灯打开,第2个人按下所有编号为2 的倍数的开关(这些灯将被关掉),第3 个人按下所有编号为3的倍数的开关(其中关掉的灯将被打开,开着的灯将被关闭),依此类推.一共有k个人,问最后有哪些灯开着?输入:n和k,输出开着的灯编号.k≤n≤100. 输入 输入一组数据:n和k 输出 输出开着的灯编号 样例输入 7 3 样例输出 1 5 6 7 #include<stdio.h>

开灯问题--------《算法竞赛入门指导》P83

开灯问题. 有n盏灯,编号为1-n.第1个人把所有灯打开,第2个人按下所有编号为2的倍数的开关(这些灯将被关掉),第3个人按下所有编号为3的倍数的开关(其中关掉的灯将被打开,开着的灯将被关闭),依此类推.一共有k个人,问最后有哪些灯开着?输入n和k,输出开着的灯的编号.k≤n≤1000.样例输入:7 3样例输出:1 5 6 7 我的代码为 #include<iostream> using namespace std; int main(void){ int n,k; cin>>n;

nyist 77 开灯问题

开灯问题时间限制:3000 ms | 内存限制:65535 KB 难度:1描述 有n盏灯,编号为1~n,第1个人把所有灯打开,第2个人按下所有编号为2 的倍数的开关(这些灯将被关掉),第3 个人按下所有编号为3的倍数的开关(其中关掉的灯将被打开,开着的灯将被关闭),依此类推.一共有k个人,问最后有哪些灯开着?输入:n和k,输出开着的灯编号.k≤n≤1000 输入 输入一组数据:n和k 输出 输出开着的灯编号 样例输入7 3样例输出1 5 6 7 #include<iostream>using

水题 开灯问题

开灯问题时间限制:3000 ms  |  内存限制:65535 KB难度:1 描述    有n盏灯,编号为1~n,第1个人把所有灯打开,第2个人按下所有编号为2 的倍数的开关(这些灯将被关掉),第3 个人按下所有编号为3的倍数的开关(其中关掉的灯将被打开,开着的灯将被关闭),依此类推.一共有k个人,问最后有哪些灯开着?输入:n和k,输出开着的灯编号.k≤n≤1000 输入    输入一组数据:n和k输出    输出开着的灯编号样例输入 7 3 样例输出 1 5 6 7 #include<iost

算法竞赛入门经典_3.1_数组_逆序输出_开灯问题

又是新的一天,继续更新. 今天进入了新的章节,数组和字符串 1.逆序输出问题: 先来看代码吧 #include <stdio.h> //逆序输出 2017-8-16 #define maxn 105 int a[maxn]; int main(int argc, char* argv[]) { //int a[maxn]; int x, n = 0; while (scanf("%d", &x) == 1) a[n++] = x; for (int i = n -

1151: 零起点学算法58——开灯问题

1151: 零起点学算法58--开灯问题 Time Limit: 1 Sec  Memory Limit: 64 MB   64bit IO Format: %lldSubmitted: 3195  Accepted: 1445[Submit][Status][Web Board] Description 计算中心有8个机房,每个机房有n台电脑.每台电脑都有一个编号,比如8号机房编号就为H1到Hn,我们有时又称为H1为1号机器,H2为2号机器,.... 有一天我们学校跻身世界高校100强,全校所

c语言实现开灯问题

开灯问题: 有n盏灯,编号为1~n,第1个人把所有灯打开,第2个人按下所有编号为2 的倍数的开关(这些灯将被关掉),第3 个人按下所有编号为3的倍数的开关(其中关掉的灯将被打开,开着的灯将被关闭),依此类推.一共有k个人,问最后有哪些灯开着?输入:n和k,输出开着的灯编号.k≤n≤1000. 附上代码: #include<stdio.h> #include<string.h> #define MAX 1000+10 int a[MAX]; int main() { int i, j