题解 | #合并表记录#

合并表记录

http://www.nowcoder.com/practice/de044e89123f4a7482bd2b214a685201

思路:
(1)n最大是500,故,准备 index[500]={0},value[500]={0},n 。 输入数据
(2) 对 index[0] -  index[n-1] 进行由小到大排序,value[0] - value[n-1] 做相同移动
(3) 遍历 index [ 0 ]到 index [n-1] 。
         for(i=0;i<n;i++)  
               for(j=i+1;j<n+1;j++)       // 不要忘记 index[ n-1 ] 要和 index[ n ]比较。
          sum=value[i]
          若 index[i] 和 index[i+1]   index[i+2] …  index[i+j] 相等,sum=sum + value[i+1] + value[i+2] + … + value[i+j] 
          当 index[i] 不等于 index[j]  时,输出 index[ j-1] 和 sum 。跳出 j 循环。进入 i  循环。
          下一个 i 循环 从 新一组 index 元素开始。 
程序:
# include <stdio.h>
# define N 11111111
int main ()
{
    int index[500]={0},value[500]={0},n;
    while(scanf("%d",&n)>0)
    {
        int i;
        for(i=0;i<n;i++)
            scanf("%d %d",&index[i],&value[i]);
        //从小到大对index排序,value一起移动
        int bigger_index=0,suixing_value=0,j;
        for(i=0;i<n-1;i++)
        {
            for(j=i+1;j<n;j++)
            {
                if(index[j]<index[i])
                {
                    //交换位置
                    bigger_index=index[i];
                    index[i]=index[j];
                    index[j]=bigger_index;
                    //value交换相同的位置
                    suixing_value=value[i];
                    value[i]=value[j];
                    value[j]= suixing_value;
                }
            }
        }
        //遍历index[0]到index[n-1].若index[i]和index[i+1]相等,sum=value[i]+value[i+1].然后输出i和sum
        int sum=0;
        for(i=0;i<n;i++)
        {
            sum=value[i];
            for(j=i+1;j<n+1;j++)
            {
                if(index[i]==index[j])
                 sum=sum+value[j];   
                else
                {
                    printf("%d %d\n",index[j-1],sum);
                    break;
                } 
            }
            i=j-1; // 下一个 i 循环 从 新一组 index 元素开始。 
        }
    }
}

全部评论

相关推荐

头像
2025-12-02 21:34
中南大学 Java
我这边应该算是华为第一批开奖的了,还是要11月底才开,不过今年的流程整体比去年确实要开得早,这一点还是值得表扬的。然后华为也确实很有诚意,给我这样bg的硕鼠开了15a,并且base地还是在杭州,应该是buff拉满了,但凡其他公司开的没这个高,and对象没签上海,可能真选择成为华孝子了。虽然很有诱惑力,但是这个15a的offer里面确实还是有猫腻的:1.&nbsp;薪资构成是这样的,15a&nbsp;=&nbsp;(基本工资+绩效工资)*12&nbsp;+&nbsp;10w年终,虽然绩效工资hr说100%能拿满,年终大部分都能拿满,绩效工资能拿满我可能还选择相信,但10w年终还能拿满,这我就存疑了。反正看了一圈别家的公司报价都是报一般情况下能拿多少年终,比如美团0-6个月,就报3.5个月,但是华似乎是喜欢往最高了报,所以估计10w年终拿满应该也是极少数人。2.&nbsp;公积金只交5%,并且缴纳基数还只是按基本工资交的,这里看似每个月到手的钱变多了,但是总体算下来,可能一年比别家就少拿1-2w。3.&nbsp;月末周六要加班,可以选择调休或双倍加班费,并且平常应该也会加班,感觉不大会像hr说的124能8.30下班,35能5.30下班的,云计算bu强度应该还算比较好的,估计一般情况下9-9-5吧,但是不知道并入ict后会如何。4.&nbsp;还有相关的业务线,听说8,9月份云计算bu内部已经调整了一波,好像还要并入ict下面了,感觉未来的不确定性也比较大。5.&nbsp;华为的认可度应该比不过传统的互联网大厂,技术的前瞻性应该也比不过(个人看法)。6.&nbsp;培养和升职,感觉美团可能更有说法,毕竟见到过1年升L6的,甚至还有两年升L7的,对华为的了解相对较少,只知道华为可能相对稳定一些?毕竟4年一签?综上,还是决定放弃华,准备去团吧,自己选的路,希望不会后悔吧。
变形钢筋:这个薪资结构,年终奖是画大饼啊
OC/开奖
点赞 评论 收藏
分享
评论
1
2
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务