B. One Bomb (#363 Div.2)

B. One Bomb
time limit per test
1 second
memory limit per test
256 megabytes
input
standard input
output
standard output

You are given a description of a depot. It is a rectangular checkered field of?n?×?m?size. Each cell in a field can be empty (".") or it can be occupied by a wall ("*").

You have one bomb. If you lay the bomb at the cell?(x,?y), then after triggering it will wipe out all walls in the row?x?and all walls in the column?y.

You are to determine if it is possible to wipe out all walls in the depot by placing and triggering?exactly one bomb. The bomb can be laid both in an empty cell or in a cell occupied by a wall.

?

Input

The first line contains two positive integers?n?and?m?(1?≤?n,?m?≤?1000)?— the number of rows and columns in the depot field.

The next?n?lines contain?m?symbols "." and "*" each?— the description of the field.?j-th symbol in?i-th of them stands for cell?(i,?j). If the symbol is equal to ".", then the corresponding cell is empty, otherwise it equals "*" and the corresponding cell is occupied by a wall.

?

Output

If it is impossible to wipe out all walls by placing and triggering exactly one bomb, then print "NO" in the first line (without quotes).

Otherwise print "YES" (without quotes) in the first line and two integers in the second line?— the coordinates of the cell at which the bomb should be laid. If there are multiple answers, print any of them.

?

Examples
input
3 4
.*..
....
.*..
output
YES
1 2
input
3 3
..*
.*.
*..
output
NO
input
6 5
..*..
..*..
*****
..*..
..*..
..*..
output
YES
3 3

?

題意:你有一個炸彈,可以放在任意位置并炸掉該位置所在的行和列上的墻“*”,求一顆炸彈是否能炸掉所有的墻。

我們可以將每行和每列的墻數分別存入數組x[]和y[]。每當a[i][j]的位置是"*"時,x[i]++,y[j]++;最后再將x[i]+y[j]與總墻數sum比較。

注意:當炸彈所在點為“*”時,需x[i]+y[j]-1;

?

附AC代碼:

 1 #include<iostream>
 2 #include<cstring>
 3 
 4 using namespace std;
 5 
 6 int N,M,ans;
 7 int a[1002][1002],x[1002],y[1002];
 8 char s[200010];
 9 
10 void process(){
11     scanf("%d %d",&N,&M);
12     int cnt = 0;
13     for(int i=1; i<=N; i++){
14         scanf("%s",s);
15         for(int j=1; j<=M; j++){
16             if(s[j-1] == '*'){
17                 x[i]++;
18                 y[j]++;
19                 cnt++;
20                 a[i][j] = 1;
21             }
22         }
23     }
24     for(int i=1; i<=N; i++){
25         for(int j=1; j<=M; j++){
26             int t;
27             t = x[i]+y[j];
28             if(a[i][j] == 1) t--;//重復一個 
29             if(t == cnt){
30                 printf("YES\n%d %d\n",i,j);
31                 return;
32             }
33         }
34     }
35     printf("NO\n");
36 }
37 
38 int main(){
39     process(); 
40     return 0;
41 }

?

轉載于:https://www.cnblogs.com/Kiven5197/p/5687391.html

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/457567.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/457567.shtml
英文地址,請注明出處:http://en.pswp.cn/news/457567.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

力扣交替打印FooBar

這道題要注意的是兩個線程喚醒和等待的順序&#xff0c;應為第一個線程會比第二個線程更早結束&#xff0c;所以如果第一個線程已經結束&#xff0c;而第二個線程還在等待被喚醒&#xff0c;那第二個線程會一直等待下去&#xff0c;因此第一個線程要先等待后喚醒&#xff0c;這…

項目開發容易出錯情況統計

2016年11月17日 11:30:45 星期四 1.適配&#xff1a; a) APP彈窗大屏幕適配&#xff08;例如&#xff0c; 是否居中&#xff09; 2.按鈕狀態&#xff1a; a) 按鈕點擊后沒有disable 如果新頁面加載卡頓導致用戶多次點擊&#xff0c;生成多次請求 b) 按鈕disable后什么時候enabl…

python會不會出4_無極4網人生苦短,Python會不會被取代?國外網友

本文經AI新媒體量子位(公眾號ID:QbitAI)授權轉載&#xff0c;轉載請聯系出處。人生苦短&#xff0c;我該不該選擇Python&#xff1f;編程語言幾年一變樣&#xff0c;榜單之爭也是愈演愈烈&#xff0c;還架不住時不時殺出個黑馬……而對于Python&#xff0c;自2010年初以來一直蓬…

android 音頻播放總結 soundlPool,MediaPlay

soundlPool 用于小音頻的播放多個同時播放。 使用步驟&#xff1a; 步驟一&#xff1a; 首先下載音頻文件可以將其放入assets文件夾下或者res下的raw文件夾下&#xff0c;區別在于assets下可以再新建文件夾而raw不行&#xff0c;assets內部單個文件超過1m時可能存在bug而raw不會…

文本分析軟件_十大針對機器學習的文本注釋工具與服務,你選哪個?

房地產和鍵【51CTO.com快譯】目前&#xff0c;從搜索引擎與情感分析&#xff0c;到虛擬助手與聊天機器人&#xff0c;機器學習應用場景中的許多研究領域&#xff0c;都需要通過文本注釋工具與服務來提供準確性。在AI研究與開發行業中&#xff0c;發現或創建可注釋的數據對于項目…

sqlite創建表

create table bike (id varchar(6) primary key, password char(6));

python 垃圾回收機制

DAY 18. python垃圾回收機制 python GC主要有三種方式 引用計數標記清除分代回收 其中&#xff0c;以引用計數為主。 18.1 引用計數&#xff08;Reference Counting&#xff09; 《尋夢環游記》中說&#xff0c;人一生會經歷兩次死亡&#xff0c;一次是肉體死的時候&#…

曲線連接線_荷重位移曲線儀操作使用注意事項-荷重位移曲線儀廠家

荷重位移曲線儀廣泛適用于各種按鍵及開關、DOME片、按鍵、微力彈片、硅膠按鍵、汽車開關之荷重-行程測定&#xff1b;Windows中英文雙語軟件&#xff0c;操作簡單方便&#xff0c;軟件流暢穩定&#xff0c;所有測試資料(測試條件&#xff0c;曲線&#xff0c;數據結果&#xff…

進程調度

1、策略 策略決定調度程序在何時讓什么進程運行。調度器的策略往往決定系統的整體印象&#xff0c;并且&#xff0c;還要負責優化使用處理器時間。 1.1 I/o消耗型和處理器消耗型。 進程可以被分為I/O消耗型和處理器消耗型。前者指進程的大部分時間用來提交I/O請求或者等待I/O請…

Django,Ajax,Vue實現文章評論功能

Django評論 評論復雜的地方在于需要實現點擊提交評論后評論內容需要立刻出現在下面&#xff0c;還要保持頁面位置不變&#xff0c;所以提交后不能整體刷新頁面&#xff0c;因為刷新以后頁面肯定在最上面&#xff0c;而評論一般都在最下面&#xff0c;所以要用到Ajax 整個過程用…

回歸分析什么時候取對數_冬蜜什么時候取,冬天取蜂蜜的方法

大家好&#xff0c;我現在分享的是&#xff0c;在冬天是在什么時候取蜜&#xff01;冬天在我們南方&#xff0c;取蜜時間是十一月到十二月的時候&#xff0c;只要溫度達到15度以上&#xff0c;蜂蜜封蓋了就可以取蜜了&#xff0c;并且在冬天我們只能取一次&#xff0c;最晚取蜜…

Opencv與dlib聯合進行人臉關鍵點檢測與識別

前言 依賴庫&#xff1a;opencv 2.4.9 /dlib 19.0/libfacedetection 本篇不記錄如何配置&#xff0c;重點在實現上。使用libfacedetection實現人臉區域檢測&#xff0c;聯合dlib標記人臉特征點&#xff0c;最后使用opencv的FaceRecognizer實現人臉識別。 準備工作 1、配置好Op…

Category 的一些事

來源&#xff1a;伯樂在線 - Tsui YuenHong 鏈接&#xff1a;http://ios.jobbole.com/90422/ 點擊 → 申請加入伯樂在線專欄作者 新增實踐部分&#xff1a;偏方 Hook 進某些方法來添加功能 Category – 簡介 Category&#xff08;類別&#xff09;是 Objective-C 2.0 添加的新特…

python tfidf特征變換_機器學習的“萬能模板” - 數據分析

最后是文本變量。很遺憾Titanic數據集中沒有合適的文本變量。一般我們處理文本變量的方法是&#xff0c;合并所有的文本形成一個變量&#xff0c;然后調用Count Vectorizer或者TfidfVectorizer算法&#xff0c;將文本數據轉換成數字。大部分情況下&#xff0c;TfidfVectorizer比…

python實現哈希表

# python 實現哈希表class HashTable:"""哈希函數的構造解決沖突"""def __init__(self, source):self.source sourceself._index []self._val []self.table []self._mod 13def Output(self):print(self._index)print(self._val)def _create…

商品綜合評價排名

店內有很多產品&#xff0c;而且包含但不局限于以下指標&#xff1a;瀏覽量、訪客數、平均停留時長、詳情頁跳出率、下單轉化率、下單支付轉化率、支付轉化率、下單金額、下單商品件數、下單買家數、支付金額、支付商品件數、加購件數、訪客平均價值、收藏人數、客單價、搜索支…

ionic資源網站

http://ionichina.com/topic/570b1f4ecd63e4247a7cfcf3 http://doc.ionicmaterialdesign.com/#intro http://ionicmaterial.com/demo/ 10大materialhttp://www.open-open.com/news/view/192f93e轉載于:https://www.cnblogs.com/znsongshu/p/6079357.html

pytorch神經網絡因素預測_實戰:使用PyTorch構建神經網絡進行房價預測

微信公號&#xff1a;ilulaoshi / 個人網站&#xff1a;lulaoshi.info本文將學習一下如何使用PyTorch創建一個前饋神經網絡(或者叫做多層感知機&#xff0c;Multiple-Layer Perceptron&#xff0c;MLP)&#xff0c;文中會使用PyTorch提供的自動求導功能&#xff0c;訓練一個神經…

SQL基本操作

SQL 操作 檢索數據 SELECT 檢索數據 -- 檢索單個列 SELECT 列名 FROM table_name;-- 檢索多個列 SELECT 列1, 列2 FROM table_name;-- 檢索所有列 SELECT * FROM table_name;-- 檢索不同的值 SELECT DISTINCT 列名 FROM table_name;限制檢索結果 -- SQL Server / Access SE…

git 忽略 部分文件夾_git提交忽略某些文件或文件夾

記得第一次用 github 提交代碼&#xff0c;node_modules 目錄死活傳不上去&#xff0c;哈哈哈&#xff0c;后來才知道在 .gitignore 文件里設置了忽略 node_modules 目錄上傳。是的&#xff0c; .gitignore 文件就是設置那些你不想用 git 一起上傳的文件和文件夾。比如剛接觸到…