📄 scramble2.cpp
字号:
/* Scalable K-means clustering softwareCopyright (C) 2000 Fredrik Farnstrom and James LewisThis program is free software; you can redistribute it and/ormodify it under the terms of the GNU General Public Licenseas published by the Free Software Foundation; either version 2of the License, or (at your option) any later version.This program is distributed in the hope that it will be useful,but WITHOUT ANY WARRANTY; without even the implied warranty ofMERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See theGNU General Public License for more details.You should have received a copy of the GNU General Public Licensealong with this program; if not, write to the Free SoftwareFoundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.See the file README.TXT for more information.*//* scramble.cpp */#include <stdio.h>#include "permutation.h"#define NUMDIMENSIONS 56#define MAXPOINTS 100000int main(int argc, char *argv[]){ long *fpos = new long[MAXPOINTS]; float tmp; int i; long k, numpoints, m; Permutation *p; FILE *f, *f2; f = fopen("cup98.dat", "r"); if(!f) { fprintf(stderr, "Error: Can't open 'cup98.dat'.\n"); delete []fpos; return 1; } f2 = fopen("cup98data.dat", "w"); if(!f) { fprintf(stderr, "Error: Can't open 'cup98data.dat' for writing.\n"); delete []fpos; fclose(f); return 1; } numpoints = 0; while(!feof(f)) { printf("%d\n", numpoints); fpos[numpoints++] = ftell(f); for(i = 0; i < NUMDIMENSIONS; i++) fscanf(f, "%f", &tmp); } p = new Permutation(numpoints); p->reset(); for(k = 0; k < numpoints; k++) { m = p->getNumber(); fseek(f, fpos[m], SEEK_SET); printf("%d %d\n", k, m); for(i = 0; i < NUMDIMENSIONS; i++) { fscanf(f, "%f", &tmp); fwrite(&tmp, sizeof(float), 1, f2);// fprintf(f2, "%f ", tmp); }// fprintf(f2, "\n"); } delete p; fclose(f); fclose(f2); delete []fpos; return 0;}
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -