- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我需要编写一个程序,以升序对连续数组元素的差异进行排序。例如:第一个和第二个元素之间的差异最小,第二个和第三个元素之间的差异较大,依此类推。我无法想出一个好的算法来以所需的方式对数组进行排序。我唯一想到的是交换两个元素的位置,然后如果顺序不正确,再次切换并保持它直到排序。我很确定它也执行得不好。
这是我的代码:
#include<stdio.h>
void InputArray(int a[], int size);
void PrintArray(int a[], int size);
void sort(int a[], int size);
void main(){
int a[100], i, n;
do{
printf("Number of elements: ");
scanf("%d", &n);
} while (n < 1 || n > 100);
InputArray(a, n);
sort(a, n);
PrintArray(a, n);
printf("\n");
}
void InputArray(int a[], int size){
printf("Enter array elements:\n");
for (int i = 0; i < size; i++)
scanf("%d", &a[i]);
}
void sort(int a[], int size){
int i, temp;
for (i = 0; ;i++){
if ((a[i] - a[i + 1]) < (a[i + 1] - a[i + 2]))
break;
temp = a[i];
a[i] = a[i + 1];
a[i + 1] = temp;
if (i == size - 1){
temp = a[size - 1];
a[size - 1] = a[0];
a[0] = temp;
i = -1;
}
}
}
void PrintArray(int a[], int size){
printf("Sorted array:\n");
for (int i = 0; i < size; i++)
printf("%d ", a[i]);
}
示例输出:
Number of elements: 4
Enter array elements:
1 3 7 12
Sorted array:
1 7 12 3
但是我在测试过程中得到了 3 1 7 12。
最佳答案
起点可以是创建一个包含所有元素之间的所有差异的 N^2 2D 矩阵,然后使用回溯解决方案。
您有一组已采用的元素和候选元素。最初采取= []候选人=[1,3,7,12]
您选择两个元素来创建第一个差异。然后选择满足升序要求的第三个元素。
如果找到,则继续,如果没有找到,则停止并返回到可以更改所取元素的位置。
如果您找到了满足要求的解决方案,则将其返回,否则您将继续搜索搜索空间。
关于C程序对两个连续数组元素的差进行升序排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49949805/
我正在做作业,经过几天的努力,我无法弄清楚为什么在实现归并排序后,我的列表仅包含链接列表中的最后一个对象。它不输出我的整个链表,只输出最后一个对象。如何更改代码以阻止列表在一个对象之后变为 null。
我想对一列进行排序(它是一个带有 Y/N 的标志列)。它应该在每次点击时在升序/降序之间切换。 我的代码不起作用..我是 VBA 新手。请提供任何帮助。 Private Sub CommandButt
我对如何让它正常工作有点困惑。我需要从用户那里获取数字(直到他们输入负数或达到最大大小),并且对于他们添加的每个数字,将其按升序插入到正确的索引中。现在,由于某种原因,即使我定义了常量 10,我的数组
我相当困惑如何创建一个按钮,将打印到 php 文件的表中的数据按升序或降序排序。 "> Order by Week Sort Week 这是我想要实现的一个简单示例,我只是停留在 php
我在使用 C++ 中的 priority_queue 时遇到问题,我有一个优先级队列 vector ,优先级队列包含多个 Person 对象。现在,我希望 priority_queue 根据年龄对 P
我正在使用 Lodash 按列对表中的数据进行排序。当我单击表格列标题中的箭头时,该特定表格列将按升序或降序排序。但是,我希望每一列首先按升序排序,而不管其他列的当前顺序如何。现在,我的函数只根据当前
如果事先知道哪些列可用,则以下代码可以重新排列列,但如果想按降序/升序重新排列列怎么办? StackOverflow 上有一些类似的帖子,但没有一篇可以在事先不知道哪些列可用的情况下这样做。 ty
在 woocommerce 中,我使用以下代码添加了自定义费用: add_action( 'woocommerce_cart_calculate_fees', 'custom_fee_based_on
这可以很好地以最多 1000 个项目的步长对数据进行分页: var q1 = (from book in table.CreateQuery() where book.PartitionKe
您好,我正在使用以下内容对表适配器返回的数据表的结果进行排序 Dim spots = myDataTable.Where(Function(t) t.UserID = 1).OrderByDesce
这可以很好地以最多 1000 个项目的步长对数据进行分页: var q1 = (from book in table.CreateQuery() where book.PartitionKe
我正在尝试获取数据库中最近的 n 个条目的列表,但将它们按升序排序。 显然我可以使用以下方法获取前 n 个条目: SELECT owner_id,message FROM messages WHERE
我尝试使用此方法将数据提取到 mysql 表 $query=$conn->query("SELECT * FROM users ORDER BY id_user ASC"); 这是我的表结构 用户 i
我正在使用 NSFetchedResultsController 在列表中显示对象 Event。 Event 对象具有 startDate 属性和 eventType 属性,它是 CheckIn 类型
我有以下代码/数据: import numpy as np data = np.array([ [12, 1, 0.7, 0], [13, 2, 0.5, 1], [41, 3
所以我是 C++ 的新手,我正在尝试一些初学者练习,这是问题所在:我必须按升序和降序对整数数组进行排序,但每次我尝试按升序排序时,都会出现 0在我的数组中无处替换以前的数组整数。只有当我使用“升序”选
在我的应用程序中,我有一个任务列表(不,它不仅仅是另一个待办事项应用程序),我使用 NSFetchedResultsController 在 UITableView 中显示任务。这是相关的初始化代码:
本人由于项目开发中需要对查询结果list进行排序,这里根据的是每一个对象中的创建时间降序排序。本人讲解不深,只实现目的,如需理解原理还需查阅更深的资料。 1.实现的效果 2.创建排序的对象
ORDER BY _column1, _column2; /* _column1升序,_column2升序 */
我需要插入两个值 num1 = 50和 num2 = 80成一个已按升序排序的数组。我不能使用动态数组或列表。也没有结构或类。这是一个类作业,所以我必须遵循指导方针。教授建议我新建一个数组,newar
我是一名优秀的程序员,十分优秀!