- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章C语言实现数组的循环左移,右移,翻转的示例由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
数组结合指针可以实现很多有趣的功能,比如下面这个程序:
假设数组为 : 12345 。
如果左移一次即为:23451 ,依次类推 。
如果右移一次即为:51234 ,依次类推 。
翻转则为:54321 。
我们来实现下这个程序:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
|
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define NR(x) (sizeof(x)/sizeof(x[0]))
//数组左移
int
buffer_left_move(
int
*buffer ,
int
buf_len)
{
int
i ;
char
tmp = buffer[0];
for
(i = 1 ; i < buf_len ; i++)
{
buffer[i-1] = buffer[i] ;
}
buffer[buf_len-1] = tmp ;
}
//数组右移
int
buffer_right_move(
int
*buffer ,
int
buf_len)
{
int
i ;
char
tmp = buffer[buf_len - 1];
for
(i = buf_len ; i > 0 ; i--)
{
buffer[i] = buffer[i-1] ;
}
buffer[0] = tmp ;
}
//数组翻转
int
buffer_turn_over(
int
*buffer ,
int
buf_len)
{
int
size = buf_len ;
int
i , tmp;
for
(i = 0 ; i < size/2 ; i++)
{
tmp = buffer[i] ;
buffer[i] = buffer[size-1-i] ;
buffer[size-1-i] = tmp;
}
}
//打印数组
void
print_buffer(
int
*buffer,
int
buf_len)
{
int
i ;
system
(
"cls"
);
printf
(
"please input \'a' or \'b' or \'w' \n"
);
for
(i = 0 ; i < buf_len ; i++)
{
printf
(
"%d"
,buffer[i]);
}
putchar
(
'\n'
);
}
int
main(
void
)
{
int
buffer[5] = {1,2,3,4,5} ;
print_buffer(buffer,NR(buffer));
while
(1)
{
switch
(getch())
{
//左边
case
'a'
:
buffer_left_move(buffer,NR(buffer)) ;
print_buffer(buffer,5);
break
;
//右边
case
'd'
:
buffer_right_move(buffer,NR(buffer));
print_buffer(buffer,5);
break
;
//翻转
case
'w'
:
buffer_turn_over(buffer,NR(buffer)) ;
print_buffer(buffer,5);
break
;
}
}
return
0 ;
}
|
运行结果:
1
2
3
|
please input
'a'
or
'b'
or
'w'
12345
|
按下a为不断左移,按下d为不断右移,按下w则为翻转 。
以上这篇C语言实现数组的循环左移,右移,翻转的示例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持我.
原文链接:https://blog.csdn.net/morixinguan/article/details/77481270 。
最后此篇关于C语言实现数组的循环左移,右移,翻转的示例的文章就讲到这里了,如果你想了解更多关于C语言实现数组的循环左移,右移,翻转的示例的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
所以我正在阅读“Java:初学者指南”并且有这样的代码: class ShowBits{ int numbits; ShowBits(int n){ numbits =
我一直在调试 C++ 库中的问题,发现文字 0 和变量设置为 0 之间存在奇怪的差异,但仅在库内部。如果我将代码复制到我自己的代码中,它就会按预期工作。 库代码将 1 向下移动一个长整数,以一次屏蔽一
这个问题已经有答案了: Is left and right shifting negative integers defined behavior? (3 个回答) 已关闭 5 年前。 在解决问题时,
我想将 num 与 scale 参数相乘。这里 num 和 scale 是 float 变量。我打算使用左移 >运算符必须是整数类型。 C11:6.5 表达式(p4): Some operators
假设我有一个二进制数。 1010 是十进制的 10。 我理解左移1位本质上是数字乘以2。 教科书中有一句话让我感到困惑。 salq %cl, %rdx %rdx 是一个数字,%salq 是一个左移。我
假设我有一个二进制数。 1010 是十进制的 10。 我理解左移1位本质上是数字乘以2。 教科书中有一句话让我感到困惑。 salq %cl, %rdx %rdx 是一个数字,%salq 是一个左移。我
在这个等式中 #define mod 1000000007 int n; int num = ((1<
我必须编写一个函数来接收 像10001这样的二进制数, 和 一个十进制数,表示我应该轮类多少次。 问题是,如果我使用 C++ 运算符 << ,从后面推零,但不会丢弃第一个数字......例如 shif
标题总结如下:左移 uint64_t 不会输出预期值,我想知道为什么。我得到的是预期结果,其 4 个最高有效字节被清零。我在 Debian Jessie 64 位上使用 x86_64 CPU(Inte
System.out.println((-1<<31)); 为什么输出 -2147483648 我知道 -1<<31 会给出 10000000000000000000000000000000,所以它应
谁能解释为什么下面的代码不能编译? byte b = 255 << 1 错误: Constant value '510' cannot be converted to a 'byte' 我期待以下二进
考虑: int a = 0; a |= 1 << a; System.out.println(a); 它打印“1”。为什么?我认为向左位移 0 任意次数仍然是 0。它从哪里拉出 1?
下面是否未定义,为什么? int i = 0xFF; unsigned int r = i << 24; 最佳答案 除非int,否则该行为在技术上是未定义的类型超过 32 位。 来自 C++11,5.
我的应用由全屏 UIWebView 提供支持。它运行良好,除非调出键盘时 View 移动了大约 10 个像素,留下一个白色间隙(请参见下面的屏幕截图)。 有谁知道造成这种情况的原因以及是否有任何解决方
有人可以解释一下 Golang 中的左移/右移行为吗?请在此处引用示例代码:https://play.golang.org/p/7vjwCbOEkw package main import (
如何让 Emacs 使用 ShiftTab 将所选文本向左移动 4 个空格? 最佳答案 为此,我使用命令indent-rigidly,绑定(bind)到C-x TAB。为其指定参数 -4,将所选区域向
这个问题已经有答案了: Remove First 16 Bytes? (4 个回答) 已关闭 8 年前。 我有一个 3 字节的字节数组:byte[] VG = new Byte[3]; 这是数组的值:
假设我有一个类,我想为其重载一个基于枚举类型的运算符: #include enum class option : char { normal, do_something_stupid }; clas
我正在尝试执行以下操作。但是我不确定我可能哪里出错了 uint64_t x = (1 = width of type [-Wshift-count-overflow] 我得到输出 0。我期待像这样的二
我正在摆弄一个 Flappy Bird 的克隆,我无法弄清楚以下代码的含义 let birdCategory: UInt32 = 1 << 0 let worldCategory: UInt32 =
我是一名优秀的程序员,十分优秀!