新网创想网站建设,新征程启航
为企业提供网站建设、域名注册、服务器等服务
两种实现方式:1)sql,2)java
创新互联建站于2013年创立,先为宁江等服务建站,宁江等地企业,进行企业商务咨询服务。为宁江企业网站制作PC+手机+微官网三网同步一站式服务解决您的所有建站问题。
1)sql语句-mysql
SELECT NAME,num,ranking
FROM (SELECT NAME,num,
IF (num =@num ,@ranking ,@ranking :=@ranking + 1)AS ranking,
@num := num
FROM score,
(SELECT @ranking := 0,@num:=-1) tmp
ORDER BY num DESC
)tmp
2) java实现
public static void main(String[] args) {
//初始化数据
ListRank ranks = Arrays.asList(new Rank("薛之谦", 100l),
new Rank("陈奕迅", 102l),
new Rank("田馥甄", 100l),
new Rank("周杰伦", 99l));
//按分数降序排序
ranks.sort((r1, r2) - r2.getNum()点抗 pareTo(r1.getNum()));
//计算排名
int ranking = 0;
long num = -1;
for (Rank rank : ranks) {
rank.setRanking(rank.getNum() == num ? ranking : ++ranking);
num = rank.getNum();
}
//输出
ranks.forEach(o - System.out.println(o.getName() + ";" + o.getNum() + ":" + o.getRanking()));
}
先定义一个学生的对象,里面有名字,和票数两个属性,再定义一个排序函数,返回值为数组,就是取得三个数的数组,打印输出,或者可以自己想一个更加面向对象的结构实现,在简单问题上多用面向对象去思考问题 。
import java.util.Scanner;
public class Test {
public static void main(String args[]) {
Scanner in = new Scanner(System.in);
int cj, yxsum = 0, tgsum = 0, bjgsum = 0;
while ((cj = in.nextInt()) != 0) {
if (cj = 85) {
yxsum++;
} else if (cj = 60) {
tgsum++;
} else {
bjgsum++;
System.out.println(yxsum);
System.out.println(tgsum);
System.out.println(bjgsum);
}
扩展资料:
当编辑并运行一个Java程序时,需要同时涉及到这四种方面。使用文字编辑软件(例如记事本、写字板、UltraEdit等)或集成开发环境(Eclipse、MyEclipse等)在Java源文件中定义不同的类;
通过调用类(这些类实现了Java API)中的方法来访问资源系统,把源文件编译生成一种二进制中间码,存储在class文件中,再通过运行与操作系统平台环境相对应的Java虚拟机来运行class文件,执行编译产生的字节码,调用class文件中实现的方法来满足程序的Java API调用。
参考资料来源:百度百科-Java
import java.lang.reflect.Array;
import java.util.Arrays;
import java.util.Scanner;
public class Test {
public static void Ballots() {
Scanner sc = new Scanner(System.in);
int[] count = new int[7];
String instr = "";
int spoiled = 0, sum = 0;
for (int i = 0; i count.length; i++) {
count[i] = 0;
}
System.out.println("输入方框数字代码投票给歌手,输入.结束 ");
do {
System.out.print("张学友[0], 刘德华[1], 小刚[2], 孙燕姿[3], 梁静茹[4], 王杰[5], 刘若英[6])? ");
instr = sc.nextLine();
if (instr.equals("0")) {
count[0]++;
} else if (instr.equals("1")) {
count[1]++;
} else if (instr.equals("2")) {
count[2]++;
} else if (instr.equals("3")) {
count[3]++;
} else if (instr.equals("4")) {
count[4]++;
} else if (instr.equals("5")) {
count[5]++;
} else if (instr.equals("6")) {
count[6]++;
} else {
if (!instr.equals(".")) {
spoiled++;
}
}
} while (!instr.equals("."));
System.out.println("投票结束,结果是 : \n");
System.out.println("歌手\t\t得票数");
System.out.println("======\t\t=========");
for (int i = 0; i count.length; i++) {
if (i == 0) {
System.out.println(" 张学友 \t\t" + count[i]);
} else if (i == 1) {
System.out.println(" 刘德华 \t\t" + count[i]);
} else if (i == 2) {
System.out.println(" 小刚 \t\t" + count[i]);
} else if (i == 3) {
System.out.println(" 孙燕姿 \t\t" + count[i]);
} else if (i == 4) {
System.out.println(" 梁静茹 \t\t" + count[i]);
} else if (i == 5) {
System.out.println(" 王杰 \t\t" + count[i]);
}else if (i == 6) {
System.out.println(" 刘若英 \t\t" + count[i]);
}
}
for (int t : count) {
sum += t;
}
System.out.println("弃权票数: " + spoiled);
System.out.println("总票数: " + sum);
}
public static void main(String[] args) {
System.out.println("投票开始:");
Scanner sc = new Scanner(System.in);
String is = "";
do {
Ballots();
System.out.println("继续第二轮投票? (y/n):");
is = sc.nextLine();
} while (is.equals("y"));
}
}
把投票的信息放在 ServletContext对象 中。也就是 JSP 内置对象中的application对象。因为投票信息是所有用户都要看的信息,所以要把他放在 ServletContext对象 中。这样只要是 应用一加载就会创建 ServletContext对象 直到应用销毁,也就是服务器关闭时,ServletContext对象 才销毁。这样就使得所有用户公用一个对象存储信息。具体的实现那要根据你自己的需求,具体设计。
public class CServlet extends HttpServlet {public void doGet(HttpServletRequest request, HttpServletResponse response)throws ServletException, IOException {int n = 0;ServletContext application = getServletContext();Integer num = (Integer) application.getAttribute("num");if (num != null) {n = num;}application.setAttribute("num", ++n);response.setContentType("text/html;charset=utf-8");PrintWriter out = response.getWriter();out.println("你是第" + n + "个访问者");}}
上面是个类似的例子。你可以参考一下。package servlet;import java.io.IOException;import java.io.PrintWriter;import javax.servlet.ServletContext;import javax.servlet.ServletException;import javax.servlet.http.HttpServlet;import javax.servlet.http.HttpServletRequest;import javax.servlet.http.HttpServletResponse;这是需要导入的包