| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 2154 人关注过本帖
标题:插队问题(请求各位高手帮忙做一下)
只看楼主 加入收藏
jx7268
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2019-6-20
结帖率:0
收藏
已结贴  问题点数:20 回复次数:1 
插队问题(请求各位高手帮忙做一下)
【问题描述】

有 n 个人(每个人有一个唯一的编号,用 1~n 之间的整数表示)在一个水龙头前排队准备接水,现在第 n 个人有特殊情况,经过协商,大家允许他插队到第 x 个位置。输出第 n 个人插队后的排队情况。

【输入格式】

第一行 1 个正整数 n,表示有 n 个人,2<n≤100。第二行包含 n 个正整数,之间用一个空格隔开,表示排在队伍中的第 1~ 第 n 个人的编号。第三行包含 1 个正整数 x,表示第 n 个人插队的位置,1≤x<n。

【输出格式】一行包含 n 个正整数,表示第 n 个人插队后的排队情况。

搜索更多相关主题的帖子: 请求 表示 一行 正整数 包含 
2019-06-20 21:24
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9031
专家分:54061
注 册:2011-1-18
收藏
得分:20 
既然是作业,为了锻炼算法能力,就不要用 STL 库了,也不要不插入而直接输出结果

程序代码:
#include <cstdio>

void foo( size_t queue[], size_t n, size_t pos )
{
    size_t tmp = queue[n-1];
    for( size_t i=n-1; i!=pos; --i )
        queue[i] = queue[i-1];
    queue[pos] = tmp;
}

int main( void )
{
    size_t n;
    size_t queue[100];
    size_t x;

    scanf( "%zu", &n );
    for( size_t i=0; i!=n; ++i )
        scanf( "%zu", queue+i );
    scanf( "%zu", &x );

    foo( queue, n, x-1 );

    for( size_t i=0; i!=n; ++i )
        printf( "%zu%c", queue[i], " \n"[i+1==n] );
}

2019-06-21 08:53
快速回复:插队问题(请求各位高手帮忙做一下)
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.016587 second(s), 8 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved