C语言/MFC 选择排序

MFC的Edit Control用法
服务器君一共花费了219.306 ms进行了5次数据库查询,努力地为您提供了这个页面。
试试阅读模式?希望听取您的建议

本文的目的是了解C语言下的选择排序,并分别在C与MFC下实现选择排序。

下面是在MFC下的程序实现:

char tmp[10] = "";
int rand_num[10];
CString str[10];
CString result;
CString sort_result;

void CNM_MFCDlg::OnBnClickedOk()
{
	CEdit* pBoxOne;
	pBoxOne = (CEdit*) GetDlgItem(IDC_EDIT1);

	srand((unsigned)time(NULL));
	for(int x=0; x<10; x++)
	{
		rand_num[x] =  rand()%100;
		str[x] = itoa(rand_num[x],tmp,10);
		result = result + str[x] + _T(" ");
	}

	pBoxOne-> SetWindowText( result );
	//MessageBox(str,_T("程序运行结果"),MB_OK);
	result.ReleaseBuffer();
}

void CNM_MFCDlg::OnBnClickedButton1()
{
	CEdit* pBoxTwo;
	pBoxTwo = (CEdit*) GetDlgItem(IDC_EDIT2);
	selection_sort(rand_num,10);

	for(int x=0; x<10; x++)
	{
		str[x] = itoa(rand_num[x],tmp,10);
		sort_result = sort_result + str[x] + _T(" ");
	}

	sort_result = sort_result + _T("~ \r\n");
	//UpdateData(false);
	pBoxTwo-> SetWindowText( sort_result );
	sort_result.ReleaseBuffer();
}

void CNM_MFCDlg::OnBnClickedCancel()
{
	CDialogEx::OnCancel();
}

void selection_sort(int *a,int n)
{
	int i,j,s;
	for(i=0;i<n-1;i++)
	{
		s=i;
		for(j=i+1;j<n;j++)
		{ 
			if(a[j]<a[i])
			{
				s=j;
			}
		}
		swap(&a[i],&a[s]);
	}
}

/*
	实现两个元素的互换
	原型:void swap(int *p1,int *p2)
	参数:int *p1:元素1的地址 
   		 int *p2:元素2的地址 
*/
void swap(int *p1,int *p2)
{
	int temp;
	temp=*p1;
	*p1=*p2;
	*p2=temp;
}

程序运行结果如下:

关于选择排序算法,其函数这样:

/*
	使用选择排序法进行排序:从小到大;
	void selection_sort(int *a,int n) 
	参数:int *a:数组名
		 int n :排序元素数
*/
void selection_sort(int *a,int n)
{
	int i,j,s;
	for(i=0;i<n-1;i++)
	{
		s=i;
		for(j=i+1;j<n;j++)
		{ 
			if(a[j]<a[i])
			{
				s=j;
			}
		}
		swap(&a[i],&a[s]);
	}
}

关于MFC下Edit Control的换行,可以用下面的方法:

sort_result = sort_result + _T("~ \r\n");

除了使用 \r\n 之外,还要对 CEdit 的属性进行设置:

Auto HScroll 设置为 False, MultiLine 设置为 True,Want Return 设置为 True。

本文地址:http://www.nowamagic.net/librarys/veda/detail/380,欢迎访问原出处。

不打个分吗? 还木有人打分噢!

转载随意,但请带上本文地址:

http://www.nowamagic.net/librarys/veda/detail/380

如果你认为这篇文章值得更多人阅读,欢迎使用下面的分享功能。
小提示:您可以按快捷键 Ctrl + D,或点此 加入收藏

大家都在看

阅读一百本计算机著作吧,少年

很多人觉得自己技术进步很慢,学习效率低,我觉得一个重要原因是看的书少了。多少是多呢?起码得看3、4、5、6米吧。给个具体的数量,那就100本书吧。很多人知识结构不好而且不系统,因为在特定领域有一个足够量的知识量+足够良好的知识结构,系统化以后就足以应对大量未曾遇到过的问题。

奉劝自学者:构建特定领域的知识结构体系的路径中再也没有比学习该专业的专业课程更好的了。如果我的知识结构体系足以囊括面试官的大部分甚至吞并他的知识结构体系的话,读到他言语中的一个词我们就已经知道他要表达什么,我们可以让他坐“上位”毕竟他是面试官,但是在知识结构体系以及心理上我们就居高临下。

所以,阅读一百本计算机著作吧,少年!

《重来:更为简单有效的商业思维》 贾森•弗里德(Jason Fried) (作者), 大卫•汉森(David Heinemeier Hansson) (作者), Mike Rohde (插图作者), 李瑜偲 (译者)

这本书呈现的是一种更好、更简单的经商成功之道。读完这本书,你就会明白为什么计划实际上百害而无一益,为什么你不需要外界投资人,为什么将竞争视而不见反倒会发展得更好。事实是你所需要的比你想象的少得多。你不必成为工作狂,你不必大量招兵买马,你不必把时间浪费在案头工作和会议上,你甚至不必拥有一间办公室。所有这些都仅仅是借口!

更多计算机宝库...