結果
| 問題 | 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