标签 知识 下的文章

C 指针*p++与*++p

关于++i与i++,我们这里纠结了不止一次,到了指针,还得接着纠结:

#include <stdio.h>

int data[2] = {100, 200};
int moredata[2] = {300, 400};
int main(void)
{
    int * p1, * p2, * p3;

    p1 = p2 = data;
    p3 = moredata;
    printf("  *p1 = %d,  *p2 = %d,  *p3 = %d\n", *p1, *p2, *p3);
    printf("  *p1++ = %d,  *++p2 = %d,  (*p3)++ = %d\n", *p1++, *++p2, (*p3)++);
    printf("  *p1 = %d,  *p2 = %d,  *p3 = %d\n", *p1, *p2, *p3);
    return 0;
}

- 阅读剩余部分 -

MYSQL 再谈JOIN

以前我们曾经在SQL 关联查找中说过JOIN,现在再次用到又学到了点新的东西。

首先还是这段代码(还是的理由是因为上一篇文章):

SELECT pr_rates.pid,count(pr_rates.ip),pr_works.title,pr_works.realname,pr_college.name FROM pr_works RIGHT JOIN pr_rates ON pr_rates.pid=pr_works.pid LEFT JOIN pr_college ON pr_works.college=pr_college.id GROUP BY pid ORDER BY count(pr_rates.ip) DESC

为什么会有Left Join Right Join,相当于一个人站在中间,左右手拉手,两个人自然是没有感觉的,其实中间一个人起到了连结的左右,他的左手连通着一个人的右手,右手连通着一个人的左手,建立了关联,于是乎因此我们选择一个与两个表都有共同项的表作为中间人,差不多就是这个意思。

MYSQL GROUP BY

GROUP BY有种合并同类项的感觉,其实也就是那个效果,我在这次的POSTER里写了一串:

SELECT pr_rates.pid,count(pr_rates.ip),pr_works.title,pr_works.realname,pr_college.name FROM pr_works RIGHT JOIN pr_rates ON pr_rates.pid=pr_works.pid LEFT JOIN pr_college ON pr_works.college=pr_college.id GROUP BY pid ORDER BY count(pr_rates.ip) DESC

其中就用到了GROUP BY pid 相当于把相同的pid合并。
然后用count()来统计就得出了得票数。

扩展阅读:
GROUP BY:http://www.w3school.com.cn/sql/sql_groupby.asp
count():http://www.w3school.com.cn/sql/sql_func_count.asp

C 猜数字讲讲输入输出

题目:

用两分搜索策略来猜数字(1-100),比如程序最初猜50,让其询问用户该猜测是大还是小,如果猜测值小,那么下一次猜测值为50-100的中值。

两分法查找的思路+练习输入输出,为了作为一个游戏增强一下卖萌性所以……还是先来看看源码吧

- 阅读剩余部分 -

C 关于递归

经过一道杨辉三角的题,总算差不多知道了关于递归的几个问题。

  1. 递归里怎么看return
  2. 为什么说递归效率低,能不用就不用

方便阅读期间,我们直接在这里再次贴出代码:

#include <stdio.h>

int Yang(int row, int col)
{
    int len = row;
    if (row == 1 || col == 1 || col == len)
        return 1;
    if (col > len)
        return 0;
    return Yang(row - 1, col - 1) + Yang(row - 1, col);
}

int main(void)
{
    int row, i;

    scanf("%d", &row);

    for (i = 1; i <= row; ++i)
        printf("%d ", Yang(row, i));
    printf("\n");

    return 0;
}

- 阅读剩余部分 -

C 逗号运算符

逗号运算符 其实就是从左到右依次执行。

百度百科:

(1) 逗号表达式的运算过程为:从左往右逐个计算表达式。
(2) 逗号表达式作为一个整体,它的值为最后一个表达式(也即表达式n)的值。
(3) 逗号运算符的优先级别在所有运算符中最低。

比如:

x = (y = 3, (z = ++y + 2) + 5);

首先y赋值为3,递增到4后加了2赋值给z,再加5,最后赋值11给x。
结果y为4 z为6 x为11

比如这个

printf("%d ", (num /= i, i));

最终输出的就是i的值。

说说循环

一个脑残竟然有点搞不清for循环是怎么进行的了,故mark一下。

for (initialize; test; update)首先先赋个初值,然后循环前先过一遍test,满足条件则循环,循环完再执行update,当然,可以选择性的写initialize,testupdate,可以用for( ; ; )把条件全变为空,这样也就可以不赋初值。不设置跳出循环的条件(如果写的不好就是死循环了),不累加。

还有两个循环都是whilefor常用于数字递增的话,while则运用于条件,do whilewhile的差别在于do while至少执行一次,一般whilefor更常用。

在我所接触的语言中,都是如此。

C 关于素数的两道题和相关算法

这道题目有点意思。

1.如果一个数是素数,则指出是素数,否则写出因数。
2.输入一个整数,显示所有小于等于该数的素数。

首先明确什么是素数再说,实际上概念我忘得差不多了:

質數,又称素数,指在大於1的自然数中,除了1和此整数自身外,無法被其他自然数整除的数(也可定義為只有1和本身两个因数的数)。

- 阅读剩余部分 -

C 谈谈switch

没学C的时候谈了一下break的作用Switch-Case中break的作用

这次来说说与if else的区别。

我时常在纠结switch case到底能不能加表达式,实际上,如果加了表达式,将会是一件异常方便的事,遗憾的是,switch只能是常量或者由常量组成的表达式(并且必须是整型值,包括char),否则的话就要用if else了(比如你需要一个范围),可见switch虽然结构清晰,条件确实坑爹。

C continue与break

continue时表示结束这次循环开始下一次循环(不运行接下来的语句),而break表示跳出循环结构。

但是continuebreak的使用根本是让循环简单化,如果复杂化了,还不如不用。