#include <iostream>
#include <random>
#include <time.h>
using namespace std;
int const N=100001;
int n,m=100,coreset[N];
double weight[N],W,s[N],pre_sum[N];
int binary_search(double v){
	int l=1,r=n;
	while (r-l>1){
		int mid=(l+r)/2;
		if (pre_sum[mid]>=v) r=mid; else l=mid+1;
	}
	if (pre_sum[l]>=v) return l;
	if (pre_sum[r]>=v) return r;
}

void work(){
	pre_sum[0]=0;
	for (int i=1;i<=n;i++)
		pre_sum[i]=pre_sum[i-1]+s[i];
	for (int i=1;i<=m;i++){
		double r=1.0*rand();
		r=r/32767;
		r=r*pre_sum[n];
		coreset[i]=binary_search(r);
		weight[i]=pre_sum[n]/s[coreset[i]]/double(m);
		W+=weight[i];
	}
}
int main(){
	srand((int)time(0));
	freopen("sensitivity.in","r",stdin);
	
	cin>>n;
	for (int i=1;i<=n;i++)
		cin>>s[i]; 
	work();
	freopen("coreset.in","w",stdout);
	cout<<m<<endl;
	for (int i=1;i<=m;i++)
		cout<<coreset[i]<<" "<<weight[i]/W*n<<endl;
	return 0;
}
