結果
| 問題 | 
                            No.8018 簡易版ページランク
                             | 
                    
| ユーザー | 
                             horiesiniti
                         | 
                    
| 提出日時 | 2016-06-22 13:50:27 | 
| 言語 | C++11(廃止可能性あり)  (gcc 13.3.0)  | 
                    
| 結果 | 
                             
                                AC
                                 
                             
                            
                         | 
                    
| 実行時間 | 14 ms / 2,000 ms | 
| コード長 | 934 bytes | 
| コンパイル時間 | 643 ms | 
| コンパイル使用メモリ | 50,352 KB | 
| 実行使用メモリ | 5,248 KB | 
| 最終ジャッジ日時 | 2024-10-11 19:19:15 | 
| 合計ジャッジ時間 | 1,416 ms | 
| 
                            ジャッジサーバーID (参考情報)  | 
                        judge5 / judge2 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| other | AC * 23 | 
コンパイルメッセージ
main.cpp: In function ‘int main()’:
main.cpp:15:14: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
   15 |         scanf("%d",&n);
      |         ~~~~~^~~~~~~~~
main.cpp:20:14: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
   20 |         scanf("%d",&m);
      |         ~~~~~^~~~~~~~~
main.cpp:23:22: warning: ignoring return value of ‘int scanf(const char*, ...)’ declared with attribute ‘warn_unused_result’ [-Wunused-result]
   23 |                 scanf("%d %d %d",&a,&b,&c);
      |                 ~~~~~^~~~~~~~~~~~~~~~~~~~~
            
            ソースコード
#include<stdio.h>
#include<map>
#include<algorithm>
#include<string.h>
const int LIMIT=1000;
std::map<int,double> mat[LIMIT];
const int LOOP=100;
int main(){
	double sum[LIMIT];
	double ans[2][LIMIT];
	int n,m;
	int now=0;
	int next=1;
	scanf("%d",&n);
	for(int i=0;i<n;i++){
		sum[i]=0;
		ans[now][i]=10.0;
	}
	scanf("%d",&m);
	for(int i=0;i<m;i++){
		int a,b,c;
		scanf("%d %d %d",&a,&b,&c);
		sum[a]+=c;
		mat[a][b]=c;
	}
	for(int i=0;i<n;i++){
		std::map<int,double>::iterator it;
		for(it=mat[i].begin();it!=mat[i].end();it++){
			(*it).second=(*it).second/sum[i];
		}
	}
	for(int i=0;i<LOOP;i++){
		memset(ans[next],0,sizeof(ans[next]));
		for(int a=0;a<n;a++){
			std::map<int,double>::iterator it;
			for(it=mat[a].begin();it!=mat[a].end();it++){
				int b=(*it).first;
				double c=(*it).second;
				ans[next][b]+=ans[now][a]*c;
			}
		}		
		std::swap(now,next);
	}
	for(int i=0;i<n;i++){
		printf("%lf\n",ans[now][i]);
	}
}
            
            
            
        
            
horiesiniti