Where is the Marble? 

Raju and Meena love to play with Marbles. They have got a lotof marbles with numbers written on them. At the beginning, Rajuwould place the marbles one after another in ascending order ofthe numbers written on them. Then Meena would ask Raju tofind the first marble with a certain number. She would count1...2...3. Raju gets one point for correct answer, and Meena getsthe point if Raju fails. After some fixed number of trials thegame ends and the player with maximum points wins. Today it'syour chance to play as Raju. Being the smart kid, you'd be takingthe favor of a computer. But don't underestimate Meena, she hadwritten a program to keep track how much time you're taking togive all the answers. So now you have to write a program, whichwill help you in your role as Raju.

Input

There can be multiple test cases. Total no of test cases is less than 65. Each test case consistsbegins with 2 integers:N the number of marbles and Q the number of queries Mina wouldmake. The next N lines would contain the numbers written on the N marbles. These marblenumbers will not come in any particular order. FollowingQ lines will have Q queries. Beassured, none of the input numbers are greater than 10000 and none of them are negative.

Input is terminated by a test case where N = 0 andQ = 0.

Output

For each test case output the serial number of the case.

For each of the queries, print one line of output. The format of this line will depend uponwhether or not the query number is written upon any of the marbles. The two different formatsare described below:

  • `x found at y', if the first marble with numberx was found at position y.Positions are numbered1, 2,..., N.
  • `x not found', if the marble with numberx is not present.

Look at the output for sample input for details.

Sample Input

4 1
2
3
5
1
5
5 2
1
3
3
3
1
2
3
0 0

Sample Output

CASE# 1:
5 found at 4
CASE# 2:
2 not found
3 found at 3

题意:

每一组数据的第一行包含两个数, 第一个数N是石头数, 第二个数Q是要找的石头编号

接下来N个石头, 数值是它们的编号

然后排序, 看看我们要找的石头是排在第几个.

做法:

我第一反应是桶排序, 不过自己还有一种方法, 所以先用自己想的方法写了一遍, 结果WA了

我的想法是: 不用排序, 一个for循环过去, 统计那些 编号值 比 我们要找的石头的编号 要小的石头个数, 并且, 标志一下数组里是否有我们要找的石头.

这个想法是简单直接的, 但是我也不知道错在哪里, 最后乖乖桶排序AC了

下面两份代码, 第一份是AC代码, 第二份是WA代码, 个人还是在深究第二份为何错, 我喜欢自己的想法~

AC:

#include<stdio.h>
#include<string.h> int main() {
int N, Q;
int cas = 0;
while(scanf("%d %d", &N, &Q) != EOF) {
if(N == 0 && Q == 0)
break; int num[10005], sum[10005];
int tmp, aim; memset(sum, 0, sizeof(sum));
memset(num, 0, sizeof(num)); for(int i = 1; i <= N; i++) {
scanf("%d", &tmp);
num[tmp]++;
} printf("CASE# %d:\n", ++cas); for(int i = 1; i <= 10000; i++)
sum[i] = num[i] + sum[i-1]; for(int i = 1; i <= Q; i++) {
scanf("%d", &aim);
if(num[aim])
printf("%d found at %d\n", aim, sum[aim-1] + 1);
else
printf("%d not found\n", aim);
}
}
return 0;
}

WA:

#include<stdio.h>

int N, Q;
int cas = 0; int main() {
while(scanf("%d %d", &N, &Q) != EOF) {
if(N == 0 && Q == 0)
break; int aim, pos, mark;
int num[10001]; for(int i = 0; i < N; i++)
scanf("%d", &num[i]); printf("CASE# %d:\n", ++cas); for(int i = 0; i < Q; i++) {
scanf("%d", &aim);
pos = 1;
mark = 0;
for(int j = 0; j < N; j++) {
if(num[j] < aim)
pos++;
if(num[j] == aim)
mark = 1;
}
if(mark == 1)
printf("%d found at %d\n", aim, pos);
else
printf("%d not found\n", aim);
}
}
return 0;
}

UVA 10474 (13.08.04)的更多相关文章

  1. UVA 156 (13.08.04)

     Ananagrams  Most crossword puzzle fans are used to anagrams--groupsof words with the same letters i ...

  2. UVA 10194 (13.08.05)

    :W Problem A: Football (aka Soccer)  The Problem Football the most popular sport in the world (ameri ...

  3. UVA 253 (13.08.06)

     Cube painting  We have a machine for painting cubes. It is supplied withthree different colors: blu ...

  4. UVA 10790 (13.08.06)

     How Many Points of Intersection?  We have two rows. There are a dots on the toprow andb dots on the ...

  5. UVA 573 (13.08.06)

     The Snail  A snail is at the bottom of a 6-foot well and wants to climb to the top.The snail can cl ...

  6. UVA 10499 (13.08.06)

    Problem H The Land of Justice Input: standard input Output: standard output Time Limit: 4 seconds In ...

  7. UVA 10025 (13.08.06)

     The ? 1 ? 2 ? ... ? n = k problem  Theproblem Given the following formula, one can set operators '+ ...

  8. UVA 465 (13.08.02)

     Overflow  Write a program that reads an expression consisting of twonon-negative integer and an ope ...

  9. UVA 10494 (13.08.02)

    点此连接到UVA10494 思路: 采取一种, 边取余边取整的方法, 让这题变的简单许多~ AC代码: #include<stdio.h> #include<string.h> ...

随机推荐

  1. php利用root权限执行shell脚本 (转)

    转一篇博客,之前搞这个东西搞了好久,结果今天晚上看到了一篇救命博客,瞬间开心了...转载转载 利用sudo来赋予Apache的用户root的执行权限,下面记录一下: 利用PHP利用root权限执行sh ...

  2. 标准c库函数与Linux下系统函数库 区别 (即带不带缓冲区的学习)

    我们都知道,C语言在UNIX/Linux系统下有一套系统调用(系统函数),比如文件操作open().close().write().read()等,而标准C语言的库函数中也有一套对文件的操作函数fop ...

  3. HTTP 的请求过程?

    当点击一个链接时,浏览器首先找到站点的IP地址,这是通过DNS来实现的,在找到IP地址后就可以建立TCP连接了,连接建立后我们就可以发送请求了.但这个请求是什么样子的呢 ? 我们现在假设点击了一个从 ...

  4. Failed to resolve: com.android.support:design:25.4.0

    韩梦飞沙  韩亚飞  313134555@qq.com  yue31313  han_meng_fei_sha 错误:(27, 13) Failed to resolve: com.android.s ...

  5. Alpha 冲刺报告6

    重感冒,重启中,停工一天

  6. [HDU6198]number number number

    题目大意: 给定一个数k表示你可以从包括0的斐波那契数列中任取k个数,得到它们的和.求最小的不能得到的自然数. 思路: 打表找规律,可以发现答案为f(2k+3)-1,然后用公式f(i)=f(i/2)* ...

  7. C/C++ 之输入输出

    因为C++向下兼容C,所以有多种输入输出的方式,cin/cout十分简洁,但个人觉得不如scanf/printf来的强大,而且在做算法题时,后者运行速度也快些. scanf/printf #inclu ...

  8. poj 3667 线段树

    题意:1 a:询问是不是有连续长度为a的空房间,有的话住进最左边2 a b:将[a,a+b-1]的房间清空思路:记录区间中最长的空房间线段树操作:update:区间替换 query:询问满足条件的最左 ...

  9. hdu 4745 区间dp

    题意:求一个环的最长回文序列,是序列不是串 链接:点我 起点是可以任意的, 所以只要求出每个区间的最长回文序列之后取max(dp[1][i]+dp[i+1][n]),即可得最终答案 本来是想扩展两倍的 ...

  10. 基于(Redis | Memcache)实现分布式互斥锁

    设计一个缓存系统,不得不要考虑的问题就是:缓存穿透.缓存击穿与失效时的雪崩效应. 缓存击穿 缓存穿透是指查询一个一定不存在的数据,由于缓存是不命中时被动写的,并且出于容错考虑,如果从存储层查不到数据则 ...