結果

問題 No.8018 簡易版ページランク
ユーザー horiesinitihoriesiniti
提出日時 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);
      |                 ~~~~~^~~~~~~~~~~~~~~~~~~~~

ソースコード

diff #

#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]);
	}
}
0