結果

問題 No.3018 簡易版ページランク
ユーザー horiesinitihoriesiniti
提出日時 2016-06-22 13:50:27
言語 C++11
(gcc 11.4.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
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 2 ms
5,248 KB
testcase_01 AC 1 ms
5,248 KB
testcase_02 AC 2 ms
5,248 KB
testcase_03 AC 1 ms
5,248 KB
testcase_04 AC 2 ms
5,248 KB
testcase_05 AC 2 ms
5,248 KB
testcase_06 AC 1 ms
5,248 KB
testcase_07 AC 2 ms
5,248 KB
testcase_08 AC 2 ms
5,248 KB
testcase_09 AC 1 ms
5,248 KB
testcase_10 AC 2 ms
5,248 KB
testcase_11 AC 1 ms
5,248 KB
testcase_12 AC 1 ms
5,248 KB
testcase_13 AC 2 ms
5,248 KB
testcase_14 AC 2 ms
5,248 KB
testcase_15 AC 2 ms
5,248 KB
testcase_16 AC 3 ms
5,248 KB
testcase_17 AC 2 ms
5,248 KB
testcase_18 AC 3 ms
5,248 KB
testcase_19 AC 4 ms
5,248 KB
testcase_20 AC 6 ms
5,248 KB
testcase_21 AC 8 ms
5,248 KB
testcase_22 AC 14 ms
5,248 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
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