亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? btest.c

?? SSD6 pq1的原版正確答案
?? C
字號:
/*  * CS:APP Data Lab  *  * btest.c - A test harness that checks a student's solution  *           in bits.c for correctness.  * * Copyright (c) 2001, R. Bryant and D. O'Hallaron, All rights reserved. * May not be used, modified, or copied without permission. * * Usage: *    -e <N>       Limit number of errors to report for single function to N *    -f <Name>    Check only the named function *    -g           Print compact grading summary (implies -v 0 and -e 0) *    -h           Print help message *    -a           Don't check the student's identifying info structure *    -r <N>       Give uniform weight of N for all problems *    -v <N>       Set verbosity level to N *                 N=0:  Only give final scores *                 N=1:  Also report individual correctness scores (default) *  * Each problem has a weight 1 to 4, which is defined in legallist.c. */#include <stdio.h>#include <stdlib.h>#include <string.h>#include <limits.h>#include "btest.h"
#include "getopt.h"/* Globals defined in other modules */extern info_struct info;    /* defined in bits.c */extern test_rec test_set[]; /* defined in decl.c */                            /* and generated from templates in ./puzzles *//* Generate test values near "corner cases" */#define TEST_RANGE 5#define TEST_COUNT 33/* Print only compact grading summary if set (-g) */static int grade = 0;/* Max errors reported per function (-e) */static int error_limit = 1000;/* If non-NULL, test only one function (-f) */static char* test_fname = NULL;  /* Should I used fixed weight for rating, and if so, what should it be? (-r)*/static int global_rating = 0;/* Return random value between min and max */static int random_val(int min, int max){    double weight = rand()/(double) RAND_MAX;    int result = (int)(min * (1-weight) + max * weight);
    return result;}/* Generate the integer values we'll use to test a function */static int gen_vals(int test_vals[], int min, int max){    int i;    int test_count = 0;    /* If range small enough, then do exhaustively */    if (max-32 <= min) {	for (i = min; i <= max; i++)	    test_vals[test_count++] = i;	return test_count;    }    /* Otherwise, need to sample.       Do so near the boundaries and for a few random cases */    for (i = 0; i < TEST_RANGE; i++) {	test_vals[test_count++] = min+i;	test_vals[test_count++] = max-i;	test_vals[test_count++] = (max+min-TEST_RANGE)/2+i;	test_vals[test_count++] = random_val(min, max);    }    return test_count;}/* Test a function with zero arguments */static int test_0_arg(funct_t f, funct_t ft, char *name, int report){    int r = f();    int rt = ft();    int error =  (r != rt);    if (error && report)	printf("Test %s() failed.\n  Gives %d[0x%x].  Should be %d[0x%x]\n",	       name, r, r, rt, rt);    return error;}/* Test a function with one argument */static int test_1_arg(funct_t f, funct_t ft, int arg1, char *name, int report){    funct1_t f1 = (funct1_t) f;    funct1_t f1t = (funct1_t) ft;    int r, rt, error;    r = f1(arg1);    rt = f1t(arg1);    error = (r != rt);    if (error && report)	printf("Test %s(%d[0x%x]) failed.\n  Gives %d[0x%x].  Should be %d[0x%x]\n",	       name, arg1, arg1, r, r, rt, rt);    return error;}/* Test a function with two arguments */static int test_2_arg(funct_t f, funct_t ft, 		      int arg1, int arg2, 		      char *name, int report){    funct2_t f2 = (funct2_t) f;    funct2_t f2t = (funct2_t) ft;    int r = f2(arg1, arg2);    int rt = f2t(arg1, arg2);    int error = (r != rt);    if (error && report)	printf(	       "Test %s(%d[0x%x],%d[0x%x]) failed.\n  Gives %d[0x%x].  Should be %d[0x%x]\n",	       name, arg1, arg1, arg2, arg2, r, r, rt, rt);    return error;}/* Test a function with three arguments */static int test_3_arg(funct_t f, funct_t ft,	   int arg1, int arg2, int arg3,	   char *name, int report){    funct3_t f3 = (funct3_t) f;    funct3_t f3t = (funct3_t) ft;    int r = f3(arg1, arg2, arg3);    int rt = f3t(arg1, arg2, arg3);    int error = (r != rt);    if (error && report)	printf(	       "Test %s(%d[0x%x],%d[0x%x],%d[0x%x]) failed.\n  Gives %d[0x%x].  Should be %d[0x%x]\n",	       name, arg1, arg1, arg2, arg2, arg3, arg3, r, r, rt, rt);    return error;}/* Test a function.  Return number of errors */static int test_function(test_ptr t, int report) {    int test_vals[3][TEST_COUNT];    int test_counts[3];    int errors = 0;    int i;    int a1, a2, a3;    int args = t->args;    /* Create test set */    for (i = 0; i < 3; i++)	test_counts[i] =	    gen_vals(test_vals[i], t->arg_ranges[i][0], t->arg_ranges[i][1]);    if (args == 0) {	errors += test_0_arg(t->solution_funct, t->test_funct,			     t->name, report && errors < error_limit);    } else for (a1 = 0; a1 < test_counts[0]; a1++) {	if (args == 1) {	    errors += test_1_arg(t->solution_funct, t->test_funct,				 test_vals[0][a1],				 t->name, report && errors < error_limit);	} else for (a2 = 0; a2 < test_counts[1]; a2++) {	    if (args == 2) {		errors += test_2_arg(t->solution_funct, t->test_funct,				     test_vals[0][a1], test_vals[1][a2],				     t->name, report && errors < error_limit);	    } else for (a3 = 0; a3 < test_counts[2]; a3++) {		errors += test_3_arg(t->solution_funct, t->test_funct,				     test_vals[0][a1], test_vals[1][a2],				     test_vals[2][a3],				     t->name, report && errors < error_limit);	    }	}    }    if (!grade) {	if (report && errors > error_limit)	    printf("... %d total errors for function %s\n",		   errors, t->name);    }    return errors;}/* Run series of tests.  Return number of errors */ static int run_tests(int report) {    int i;    int errors = 0;    double points = 0.0;    double max_points = 0.0;    if (grade)	printf("Score\tErrors\tFunction\n");    for (i = 0; test_set[i].solution_funct; i++) {	int terrors;	double tscore;	double tpoints;	if (!test_fname || strcmp(test_set[i].name,test_fname) == 0) {	    int rating = global_rating ? global_rating : test_set[i].rating;	    terrors = test_function(&test_set[i], report);	    errors += terrors;	    if (test_set[i].args == 0)		tscore = terrors == 0 ? 1.0 : 0.0;	    else		tscore = terrors == 0 ? 1.0 : terrors == 1 ? 0.5 : 0.0;	    tpoints = rating * tscore;	    points += tpoints;	    max_points += rating;	    if (grade)		printf(" %.1f\t%d\t%s\n", tpoints, terrors, test_set[i].name);	    if (report)		printf("Test %s score: %.2f/%.2f\n",		       test_set[i].name, tpoints, (double) rating);	}    }    if (grade) 	printf("Total points: %.2f/%.2f\n", points, max_points);    else	printf("Overall correctness score: %.2f/%.2f\n", points, max_points);    return errors;}static void usage(char *cmd) {    printf("Usage: %s [-v 0|1] [-hag] [-f <func name>] [-e <max errors>]\n", cmd);    printf("  -e <n>    Limit number of errors to report for single function to n\n");    printf("  -f <name> Check only the named function\n");    printf("  -g        Print compact grading summary (implies -v 0 and -e 0)\n");    printf("  -h        Print this message\n");    printf("  -a        Omit check for valid info struct\n");    printf("  -r <n>    Give uniform weight of n for all problems\n");    printf("  -v <n>    Set verbosity to level n\n");    printf("               n=0: Only give final scores\n");    printf("               n=1: Also report individual correctness scores (default)\n");    exit(1);}/*  * main routine  */int main(int argc, char *argv[]){    int verbose_level = 1;    int errors;    int info_check = 1;    char c;    /* parse command line args */     while ((c = getopt(argc, argv, "hagv:f:e:r:")) != -1)        switch (c) {        case 'h': /* help */	    usage(argv[0]);	    break;        case 'a': /* Don't check info structure */	    info_check = 0;	    break;        case 'g': /* grading summary */	    grade = 1;	    break;        case 'v': /* set verbosity level */	    verbose_level = atoi(optarg);	    if (verbose_level < 0 || verbose_level > 1)		usage(argv[0]);	    break;	case 'f': /* test only one function */	    test_fname = strdup(optarg);	    break;	case 'e': /* set error limit */	    error_limit = atoi(optarg);	    if (error_limit < 0)		usage(argv[0]);	    break;	case 'r': /* set global rating for each problem */	    global_rating = atoi(optarg);	    if (global_rating < 0)		usage(argv[0]);	    break;	default:	    usage(argv[0]);    }
    if (grade) {	  error_limit = 0;	  verbose_level = 0;    }    if (info_check) {      /* Students must fill in their identifying info */      if ((*info.name == '\0')) {	printf("%s: ERROR.  You must fill in the name member of the info_struct in bits.c!\n", argv[0]);	exit(1);      }       if ((*info.id == '\0')) {	printf("%s: ERROR.  You must fill in the id member of the info_struct in bits.c!\n", argv[0]);	exit(1);      }     }    /* test each function */    errors = run_tests(verbose_level > 0);    if (!grade) {	if (errors > 0)	    printf("%d errors encountered.\n", errors);	else {	    printf("All tests passed.\n");	}    }    return 0;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美精品久久久久久久久老牛影院| 亚洲国产美国国产综合一区二区 | 91亚洲国产成人精品一区二区三 | 亚洲大尺度视频在线观看| 狠狠网亚洲精品| 色噜噜久久综合| 久久久久久久久岛国免费| 午夜久久久久久久久久一区二区| 成人在线综合网站| 精品久久久三级丝袜| 五月综合激情日本mⅴ| 一本色道久久综合亚洲精品按摩| 久久亚洲影视婷婷| 蜜桃av噜噜一区| 欧美日韩大陆一区二区| 亚洲激情中文1区| 成人动漫一区二区| 中文在线一区二区| 精品伊人久久久久7777人| 欧美一区二区三区在线视频| 亚洲小说春色综合另类电影| 欧洲av一区二区嗯嗯嗯啊| 国产精品国产三级国产普通话三级| 毛片av一区二区| 欧美一级黄色片| 日韩 欧美一区二区三区| 欧美精品久久一区| 日韩高清不卡在线| 91精品国产综合久久小美女| 青娱乐精品视频| 欧美日韩国产高清一区二区三区 | 裸体健美xxxx欧美裸体表演| 日韩欧美国产小视频| 久久99精品久久久久久国产越南| 日韩欧美亚洲一区二区| 极品少妇xxxx精品少妇偷拍| 精品日韩一区二区| 国产精品一区二区三区99| 国产午夜亚洲精品午夜鲁丝片| 精品一区二区三区免费视频| 亚洲精品一区二区三区影院 | 国产精品一区二区免费不卡| 国产亚洲精久久久久久| 成人福利电影精品一区二区在线观看| 国产精品欧美一区二区三区| 91国偷自产一区二区使用方法| 亚洲国产精品久久人人爱| 欧美日韩国产精品成人| 韩国欧美国产一区| 中文无字幕一区二区三区| 91农村精品一区二区在线| 综合电影一区二区三区 | 久久99在线观看| 国产欧美日韩综合| 色综合久久66| 蜜臀av性久久久久蜜臀av麻豆 | 精品久久久久久久久久久久久久久久久 | 精品一二三四在线| 国产精品色在线观看| 欧美三片在线视频观看| 麻豆国产欧美日韩综合精品二区| 国产日产亚洲精品系列| 欧美中文一区二区三区| 精品在线一区二区| 亚洲人成人一区二区在线观看 | 国产乱码精品一区二区三区五月婷| 国产精品久久久久久久久久免费看| 色8久久精品久久久久久蜜| 日本三级亚洲精品| 中文字幕日本不卡| 欧美v国产在线一区二区三区| 成人视屏免费看| 五月激情综合婷婷| 国产精品免费aⅴ片在线观看| 69久久99精品久久久久婷婷| www.在线欧美| 激情av综合网| 亚洲成av人**亚洲成av**| 欧美激情一区二区在线| 欧美电影在哪看比较好| 91在线免费看| 国模一区二区三区白浆| 偷拍日韩校园综合在线| 亚洲人xxxx| 国产精品日产欧美久久久久| 精品国精品国产尤物美女| 欧美日韩激情一区二区三区| thepron国产精品| 国产一区二区在线视频| 青青青爽久久午夜综合久久午夜| 樱桃视频在线观看一区| 国产亲近乱来精品视频 | 福利一区二区在线| 九九久久精品视频| 日本成人在线网站| 同产精品九九九| 亚洲一区二区三区三| 日韩一区日韩二区| 国产精品无遮挡| 国产欧美视频一区二区| 精品对白一区国产伦| 91精品在线观看入口| 欧美视频在线一区| 欧美性高清videossexo| 日本二三区不卡| 色综合久久88色综合天天免费| eeuss国产一区二区三区| 国产69精品久久久久毛片| 国产成a人亚洲精| 高清不卡一区二区在线| 粉嫩一区二区三区在线看| 国产xxx精品视频大全| 黄网站免费久久| 国产成人综合网| 成人v精品蜜桃久久一区| 波多野结衣中文字幕一区二区三区| 国产精品羞羞答答xxdd| 丰满放荡岳乱妇91ww| 成人黄色电影在线 | 成人av资源下载| 高清视频一区二区| 99久久99久久精品免费看蜜桃| 91美女在线看| 欧美午夜片在线观看| 日韩一卡二卡三卡四卡| 精品88久久久久88久久久| 国产清纯在线一区二区www| 中文字幕在线观看一区二区| 国产一区二区91| 国产福利一区二区三区视频在线| 亚洲成人777| 亚洲国产欧美在线| 日日摸夜夜添夜夜添亚洲女人| 青青草91视频| 国产福利91精品| 91毛片在线观看| 日韩一区二区三区三四区视频在线观看 | 久久久影院官网| 一区在线播放视频| 天天色天天爱天天射综合| 韩日欧美一区二区三区| 成人18精品视频| 国产日韩欧美综合一区| 欧美一级二级三级蜜桃| 国产欧美一区二区精品秋霞影院| 亚洲欧美一区二区三区极速播放 | 国产真实精品久久二三区| 成人av电影观看| 精品视频免费在线| 久久天堂av综合合色蜜桃网| 一区二区高清视频在线观看| 免费人成网站在线观看欧美高清| 国产91精品一区二区| 欧美群妇大交群的观看方式| 久久久久久久久免费| 午夜久久久久久电影| 丁香亚洲综合激情啪啪综合| 欧美日韩国产综合一区二区三区| 久久精品一级爱片| 亚洲大尺度视频在线观看| 国产成人精品免费在线| 这里只有精品视频在线观看| 国产女人18水真多18精品一级做| 日韩专区在线视频| av中文字幕不卡| 精品欧美久久久| 亚洲国产美国国产综合一区二区| 丁香桃色午夜亚洲一区二区三区| 欧美美女激情18p| 国产精品国产自产拍高清av | 国产精品系列在线| 青青草伊人久久| 精品视频色一区| 亚洲三级理论片| 国产成人丝袜美腿| 欧美精品一区二区三区很污很色的| 亚洲高清免费一级二级三级| 99视频精品免费视频| 国产亚洲欧美色| 久久 天天综合| 欧美精品自拍偷拍动漫精品| 亚洲激情一二三区| 99re免费视频精品全部| 国产三级精品视频| 国产乱子轮精品视频| 日韩精品一区二区在线| 青青草原综合久久大伊人精品| 欧美日韩综合不卡| 亚洲电影一区二区三区| 色呦呦国产精品| 亚洲欧美日韩国产另类专区| 91在线免费看| 亚洲视频一二三区| 色偷偷久久一区二区三区| 专区另类欧美日韩| 99国产精品久久久久久久久久 | 激情图片小说一区| 精品国产乱码久久久久久免费| 老司机免费视频一区二区三区| 日韩一卡二卡三卡四卡|