摘要:
原题链接这题需要一些小技巧。附ac代码:#include int main(){ int t, n, m, count, x; scanf("%d", &t); while(t-- && scanf("%d%d", &n, &m)){ count = 0; n -= n % m; while(n >= m){ x = n; while(x % m == 0){ ++count; x /= m; } n -= m; } printf("%d\n", count); } return 0;}再 阅读全文
posted @ 2014-02-11 23:54
长木Qiu
阅读(138)
评论(0)
推荐(0)
摘要:
原题链接直接用log10函数。注意结果要保存到double中。附ac代码: #include #include int main(){ int n, t; double count; scanf("%d", &t); while(t-- && scanf("%d", &n)){ count = 1; while(n) count += log10(n--); printf("%d\n", (int)count); } return 0;} 再附上NYOJ上的标程:(感谢原作者feihu) /* NYOJ 阅读全文
posted @ 2014-02-11 22:19
长木Qiu
阅读(134)
评论(0)
推荐(0)
摘要:
原题链接考察数学知识(百度了好久才找到这个数学知识点):在平面上作向量AB、ACAB叉乘AC为正,则是逆时针,为负为顺时针.记向量AB为(dx1, dy1) = (x2-x1, y2-y1)向量AC为(dx2, dy2) = (x3-x1, y3-y1)叉积为|dx1 dy1||dx2 dy2|即:dx1 * dy2 - dy1 * dx2附ac代码:#include int main(){ int x1, y1, x2, y2, x3, y3, x4, y4, x5, y5, t; while(scanf("%d%d%d%d%d%d", &x1, &y1, 阅读全文
posted @ 2014-02-11 21:45
长木Qiu
阅读(149)
评论(0)
推荐(0)
摘要:
原题链接已知三角形PMN三个顶点坐标为(x1, y1) (x2, y2) (x3, y3),求该三角形的面积SS = |(x1y2+y1x3+x2y3-x1y3-y1x2-y2x3)| / 2知道这个公式就好办了。附ac代码:#include #include int main(){ int x1, y1, x2, y2, x3, y3; while(scanf("%d%d%d%d%d%d", &x1, &y1, &x2, &y2, &x3, &y3), x1 || y1 || x2 || y2 || x3 || y3) pr 阅读全文
posted @ 2014-02-11 17:55
长木Qiu
阅读(145)
评论(0)
推荐(0)
摘要:
原题链接关键点是通分后判断分子分母能否整除附ac代码:#include int main(){ int t, k, x, y, tempa, tempb; scanf("%d", &t); while(t-- && scanf("%d", &k)){ for(y = k + 1; y = y) printf("1/%d=1/%d+1/%d\n", k, x, y); } } } return 0;} 阅读全文
posted @ 2014-02-11 17:24
长木Qiu
阅读(166)
评论(0)
推荐(0)
摘要:
原题链接考察对字符串的操作。将各个字符出现的次数保存到数组中,重复出现的赋值为 ‘.’, 再将数组降序排序,后面就简单了。附ac代码:#include #include #include #include int cmp(const void *a, const void *b){ return *(int *)b - *(int *)a;}int f(int n){ //判断素数 if(n < 2) return 0; for(int i = 2; i <= sqrt(n); ++i) if(n % i == 0) return 0; return 1;}int main(){ 阅读全文
posted @ 2014-02-11 16:43
长木Qiu
阅读(112)
评论(0)
推荐(0)
摘要:
原题链接难点是用节点表示学生信息,并增加一个变量保存奖学金金额。附ac代码:#include #include struct Node{ char name[21], gov[2], min[2]; int test, ctest, paper, scholarship;};struct node{ int maxsch, subscript;};void judge(Node *stu){ //一等奖学金 if(stu->test > 80 && stu->paper) stu->scholarship += 8000; //二等奖学金 if(stu- 阅读全文
posted @ 2014-02-11 16:04
长木Qiu
阅读(142)
评论(0)
推荐(0)
摘要:
原题链接简单题附ac代码:#include struct Unhappy{ int day, time;};int main(){ Unhappy stu; int t, a, b; scanf("%d", &t); while(t--){ stu.time = stu.day = 0; int i = 0; while(i++ stu.time) stu.time = a + b - 8, stu.day = i; } printf("%d\n", stu.day); } return 0;} 阅读全文
posted @ 2014-02-11 15:11
长木Qiu
阅读(133)
评论(0)
推荐(0)
摘要:
原题链接简单题。附ac代码:#include int main(){ int t, a[10], i, height, count; scanf("%d", &t); while(t--){ for(i = count = 0; i != 10; ++i) scanf("%d", &a[i]); scanf("%d", &height); height += 30; for(i = 0; i != 10; ++i) if(height >= a[i]) ++count; printf("%d\n 阅读全文
posted @ 2014-02-11 14:54
长木Qiu
阅读(155)
评论(0)
推荐(0)
摘要:
原题链接这题真奇葩,在输出的行末加了回车竟然WA,把回车换成空格就ac,真无语,史上最烂题。附ac代码: #include #include int a[1001];int cmp(const void *a, const void *b){ return *(int *)a - *(int *)b;}int main(){ int n, t, count; scanf("%d", &n); int i = 0; count = n; while(i != n) scanf("%d", &a[i++]); qsort(a, n, size 阅读全文
posted @ 2014-02-11 14:27
长木Qiu
阅读(140)
评论(0)
推荐(0)
摘要:
原题链接简单题。附ac代码:#include int len( int n ){ int i = 1; while( n != 1 ){ if( n & 1 ) n = 3 * n + 1; else n >>= 1; ++i; } return i;}int main(){ int i, j, maxlen, ii, jj; while( scanf( "%d%d", &i, &j ) == 2 ){ i maxlen ) ... 阅读全文
posted @ 2014-02-11 13:59
长木Qiu
阅读(114)
评论(0)
推荐(0)
摘要:
原题链接这题和hdu 1032一样,令人郁闷的是在hdu ac的代码拿到nyoj就TLE了,然后果断加上打表,就过了。附ac代码:#include #define MAX 10001int a[MAX];int len( int n ){ int i = 1; while( n != 1 ){ if( n & 1 ) n = 3 * n + 1; else n >>= 1; ++i; } return i;}void CountA(){ for(int i = 1; i != MAX;... 阅读全文
posted @ 2014-02-11 13:55
长木Qiu
阅读(122)
评论(0)
推荐(0)
摘要:
原题链接一道略有技巧性的简单题。附ac代码:#include #define MAX 101int a[MAX][MAX];int main(){ int n, x, y, count = 1; scanf("%d", &n); a[x = 0][y = n - 1] = 1; while(count = 0 && !a[x][y - 1]) //向左填 a[x][--y] = ++count; while(x - 1 >= 0 && !a[x - 1][y]) //向上填 a[--x][y] = ++count; while( 阅读全文
posted @ 2014-02-11 11:15
长木Qiu
阅读(141)
评论(0)
推荐(0)
摘要:
原题链接标准水题。ac代码:#include int main(){ int a[3][3], t; scanf("%d", &t); while(t--){ for(int i = 0; i != 3; ++i) for(int j = 0; j != 3; ++j) scanf("%d", &a[j][i]); for(int i = 0; i != 3; ++i){ for(int j = 0; j != 3; ++j){ printf("%d", a[i][j]); if(j != 2) putchar( 阅读全文
posted @ 2014-02-11 01:00
长木Qiu
阅读(185)
评论(0)
推荐(0)
摘要:
原题链接简单题,但是要注意特殊情况,比如0+0, .123+.123等。附ac代码:#include #include #define MAX 400 + 10char a0[MAX], b0[MAX], s[MAX], aa[MAX], bb[MAX], ss0[MAX]; //aa保存整数,a保存小数int main(){ char *dot; while( scanf( "%s%s", a0, b0 ) == 2 ){ char *a = a0, *b = b0, *ss = ss0; aa[0] = bb[0] = '0'; //留着进位 ... 阅读全文
posted @ 2014-02-11 00:36
长木Qiu
阅读(113)
评论(0)
推荐(0)
摘要:
原题链接简单题。附ac代码:#include #define MAX 20000int a[MAX];//最高位在末尾非零项void Compute(int n){ int i, j, t; for(i = MAX - 1; i; --i) if(a[i]) break; //找到末尾 j = i; for(i = 0; i = 0; --j) printf("%d", a[j]); putchar('\n'); return 0;} 阅读全文
posted @ 2014-02-11 00:26
长木Qiu
阅读(142)
评论(0)
推荐(0)